第十四届蓝桥杯省赛C++B组I题【景区导游】题解(AC)

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

解题思路

题目已给出地图为一个 n n n 个点, n − 1 n-1 n1 条路线的树。

对于计算树中任意两点的距离,我们可以使用 LCA 算法进行快速计算。

假设 a , b a, b a,b 的最近公共祖先为 c c c,那么 a , b a,b a,b 之间的距离为 d i s t [ a ] + d i s t [ b ] − 2 × d i s t [ c ] dist[a]+dist[b]-2\times dist[c] dist[a]+dist[b]2×dist[c],其中 d i s t [ x ] dist[x] dist[x] 表示从根节点到 x x x 点的距离。

所以我们可以先算出原定路线所消耗的时间 r e s res res,再进行删点删边操作:

  1. 假设删掉的为第 1 1 1 个点,相当于删掉从 1 1 1 号点到 2 2 2 号点的边,相当于从 2 2 2 号点开始。那么答案应该等于
    r e s − g e t _ d i s t ( q [ 1 ] , q [ 2 ] ) res - get\_dist(q[1], q[2]) resget_dist(q[1],q[2])
  2. 假设删掉的为第 i ( 1 < i < m ) i(1<i<m) i(1<i<m) 个点,相当于删掉从 i − 1 i-1 i1 号点到 i i i 号点的边和从 i i i 号点到 i + 1 i+1 i+1 号点的边,并且补上一条从 i − 1 i-1 i1 号点到 i + 1 i+1 i+1 号点的边,那么答案应该等于
    r e s − g e t _ d i s t ( q [ i − 1 ] , q [ i ] ) − g e t _ d i s t ( q [ i ] , q [ i + 1 ] ) + g e t _ d i s t ( q [ i − 1 ] , q [ i + 1 ] ) res - get\_dist(q[i - 1], q[i]) - get\_dist(q[i], q[i + 1]) + get\_dist(q[i - 1], q[i + 1]) resget_dist(q[i1],q[i])get_dist(q[i],q[i+1])+get_dist(q[i1],q[i+1])
  3. 假设删掉的为第 m m m 个点,相当于删掉从 m − 1 m-1 m1 号点到 m m m 号点的边,相当于从 m − 1 m-1 m1 号点结束。那么答案应该等于
    r e s − g e t _ d i s t ( q [ m − 1 ] , q [ m ] ) res - get\_dist(q[m-1], q[m]) resget_dist(q[m1],q[m])

AC_Code

#include <iostream>
#include <cstring>
#include <algorithm>
#include <queue>using namespace std;typedef long long LL;const int N = 1e5 + 10, M = N * 2;int n, m;
int h[N], e[M], w[M], ne[M], idx;
int depth[N];
LL dist[N];
int fa[N][20];
int q[N];void add(int a, int b, int c)
{e[idx] = b, w[idx] = c, ne[idx] = h[a], h[a] = idx ++;
}void bfs()
{memset(depth, 0x3f, sizeof depth);depth[0] = 0, depth[1] = 1;queue<int> q;q.push(1);while (q.size()){auto t = q.front();q.pop();for (int i = h[t]; ~i; i = ne[i] ){int j = e[i];if (depth[j] <= depth[t] + 1)continue;depth[j] = depth[t] + 1;dist[j] = dist[t] + w[i];fa[j][0] = t;for (int k = 1; k <= 19; ++ k )fa[j][k] = fa[fa[j][k - 1]][k - 1];q.push(j);}}
}int get_lca(int a, int b)
{if (depth[a] < depth[b])swap(a, b);for (int i = 19; i >= 0; -- i )if (depth[fa[a][i]] >= depth[b])a = fa[a][i];if (a == b)return a;for (int i = 19; i >= 0; -- i )if (fa[a][i] != fa[b][i]){a = fa[a][i];b = fa[b][i];}return fa[a][0];
}LL get_dist(int a, int b)
{int c = get_lca(a, b);return dist[a] + dist[b] - dist[c] * 2;
}int main()
{ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);cin >> n >> m;memset(h, -1, sizeof h);for (int i = 0; i < n - 1; ++ i ){int a, b, c;cin >> a >> b >> c;add(a, b, c), add(b, a, c);}for (int i = 1; i <= m; ++ i )cin >> q[i];bfs();LL res = 0;for (int i = 1; i <= m - 1; ++ i )res += get_dist(q[i], q[i + 1]);for (int i = 1; i <= m; ++ i ){if (i == 1)cout << res - get_dist(q[1], q[2]) << ' ';else if (i < m)cout << res - get_dist(q[i - 1], q[i]) - get_dist(q[i], q[i + 1]) + get_dist(q[i - 1], q[i + 1]) << ' ';elsecout << res - get_dist(q[m - 1], q[m]) << ' ';}cout << endl;return 0;
}

【在线测评】

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/874230.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

太速科技-基于XCVU9P+ C6678的8T8R的无线MIMO平台

基于XCVU9P C6678的8T8R的无线MIMO平台 一、板卡概述 板卡基于TI TMS320C6678 DSP和XCVU9P高性能FPGA&#xff0c;FPGA接入4片AD9361 无线射频&#xff0c;构建8输入8输出的无线MIMO平台&#xff0c;丰富的FPGA资源和8核DSP为算法验证和信号处理提供强大能力。 二…

python:本机摄像头目标检测实时推理(使用YOLOv8n模型)

本文将介绍如何使用本机摄像头进行目标检测实时推理的python代码。 文章目录 一、下载YOLO权重文件二、环境配置三、完整代码 一、下载YOLO权重文件 https://github.com/ultralytics/ultralytics?tabreadme-ov-file 拉到网页最下面&#xff0c;选择适合的模型&#xff0c;下…

【引领未来智造新纪元:量化机器人的革命性应用】

在日新月异的科技浪潮中&#xff0c;量化机器人正以其超凡的智慧与精准的操作&#xff0c;悄然改变着各行各业的生产面貌&#xff0c;成为推动产业升级、提升竞争力的关键力量。今天&#xff0c;让我们一同探索量化机器人在不同领域的广泛应用价值&#xff0c;见证它如何以科技…

sql注入的专项练习(含代码审计)

在做题之前先复习了数据库的增删改查&#xff0c;然后自己用本地的环境&#xff0c;在自己建的库里面进行了sql语句的测试&#xff0c;主要是回顾了一下sql注入联合注入查询的语句和sql注入的一般做题步骤。 1.获取当前数据库 2.获取数据库中的表 3.获取表中的字段名 一、sql…

饥荒dst联机服务器搭建基于Ubuntu

目录 一、服务器配置选择 二、项目 1、下载到服务器 2、解压 3、环境 4、启动面板 一、服务器配置选择 首先服务器配置需要2核心4G&#xff0c;4G内存森林加洞穴大概就占75% 之后进行服务器端口的开放&#xff1a; tcp:8082 tcp:8080 UDP:10888 UDP:10998 UDP:10999 共…

TiDB实践—索引加速+分布式执行框架创建索引提升70+倍

作者&#xff1a; 数据源的TiDB学习之路 原文来源&#xff1a; https://tidb.net/blog/92d348c2 背景介绍 TiDB 采用在线异步变更的方式执行 DDL 语句&#xff0c;从而实现 DDL 语句的执行不会阻塞其他会话中的 DML 语句。按照是否需要操作 DDL 目标对象所包括的数据来划分…

Nest.js 实战 (四):利用 Pipe 管道实现数据验证和转换

什么是管道&#xff08;Pipe&#xff09;&#xff1f; 在 Nest.js 中&#xff0c;管道&#xff08;Pipelines&#xff09; 是一种强大的功能&#xff0c;用于预处理进入控制器方法的请求数据&#xff0c;如请求体、查询参数、路径参数等。管道允许开发者在数据到达控制器方法之…

BGP协议的综合实验

目录 文章目录 一、题目 二、题目分析 题目需求 IP地址的划分 三、实验配置 IP地址配置 OSPF配置 检查OSPF配置&#xff1a; BGP配置 配置反射器 宣告1.1.1.1/8.8.8.8 查看结果 减少路由条目数量 配置GRE环境 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供…

yolo5图片视频、摄像头推理demo

yolo5图片、视频推理demo 图片 import torch# 加载预训练模型 model torch.hub.load(./yolo5, custom, pathyolov5s.pt, sourcelocal)# 加载图片 img 1.jpg# 进行推理 results model(img)# 解析结果 detections results.xyxy[0].cpu().numpy() # [x1, y1, x2, y2, confid…

【好玩的经典游戏】Docker环境下部署赛车小游戏

【好玩的经典游戏】Docker环境下部署赛车小游戏 一、小游戏介绍1.1 小游戏简介1.2 项目预览二、本次实践介绍2.1 本地环境规划2.2 本次实践介绍三、本地环境检查3.1 安装Docker环境3.2 检查Docker服务状态3.3 检查Docker版本3.4 检查docker compose 版本四、构建容器镜像4.1 下…

全自动蛋托清洗机介绍:

全自动蛋托清洗机&#xff0c;作为现代蛋品处理设备的杰出代表&#xff0c;凭借其高效、智能、环保的特性&#xff0c;正逐步成为蛋品加工行业的得力助手。 这款清洗机采用了先进的自动化设计理念&#xff0c;从进料、清洗到出料&#xff0c;全程无需人工干预&#xff0c;极大…

C++:类与对象(下)

前言&#xff1a; 前言&#xff1a; 上一篇博客我们介绍了类与对象中的几类默认成员函数&#xff0c;这篇让我们继续来学习类与对象吧&#xff01; 个人主页&#xff1a;Pianeers 文章专栏&#xff1a;C 如果有问题&#xff0c;欢迎评论区讨论&#xff01; 希望能帮到大家&…

【数据脱敏】⭐️SpringBoot 整合 Jackson 实现隐私数据加密

目录 &#x1f378;前言 &#x1f37b;一、Jackson 序列化库 &#x1f37a;二、方案实践 2.1 环境准备 2.2 依赖引入 2.3 代码编写 &#x1f49e;️三、接口测试 &#x1f379;四、章末 &#x1f378;前言 小伙伴们大家好&#xff0c;最近也是很忙啊&#xff0c;上次的文章…

C++与VLC制作独属于你的动态壁纸背景

文章目录 前言效果展示为什么要做他如何实现他实现步骤获取桌面句柄代码获取桌面句柄libvlc_media_player_set_hwnd函数 动态壁纸代码 总结 前言 在当今的数字世界中&#xff0c;个性化和自定义化的体验越来越受到人们的欢迎。动态壁纸是其中一种很受欢迎的方式&#xff0c;它…

【教学类-70-01】20240722镜子花边(适配5CM圆镜)

背景需求 我想给孩子们做一个小圆镜&#xff0c;花边涂色&#xff0c;打洞&#xff0c;做一个项链样式 1、使用通义万相生成了“圆形镜子&#xff0c;有花边” 边缘细&#xff0c;黑色面积大的图片放到另外一个文件夹里&#xff08;不用&#xff09; 从性价比角度&#xff…

Qt窗口介绍

Qt窗口 一、Qt窗口二、菜单栏创建菜单栏在菜单栏中添加菜单创建菜单项在菜单项之间添加分割线综合练习 三、工具栏创建工具栏设置停靠位置设置浮动属性设置移动属性综合练习 四、状态栏状态栏的创建在状态栏中显示实时消息在状态栏显示永久的消息 五、浮动窗口浮动窗口的创建设…

Pytorch实现图像分类-水果数据集分类--深度学习大作业

目录 1.概述 2.设计 3.实现 4.实验 5.总结 1.概述 本次深度学习大作业&#xff0c;我使用AlexNet模型对"Fruits-360"数据集中的两部分水果和蔬菜图片进行分类 2.设计 模型设计&#xff1a;Alexnet网络 卷积层部分&#xff1a;构建了一系列卷积层、激活函数…

【等保测评】服务器——Windows server 2012 R2

文章目录 **身份鉴别****访问控制****安全审计****入侵防范****恶意代码防范****可信验证****测评常用命令** Windows服务器安全计算环境测评 测评对象&#xff1a;Windows server 2012 R2 身份鉴别 &#xff08;高风险&#xff09;应对登录的用户进行身份标识和鉴别&#x…

【爱上C++】list用法详解、模拟实现

文章目录 一&#xff1a;list介绍以及使用1.list介绍2.基本用法①list构造方式②list迭代器的使用③容量④元素访问⑤插入和删除⑥其他操作image.png 3.list与vector对比 二&#xff1a;list模拟实现1.基本框架2.节点结构体模板3.__list_iterator 结构体模板①模板参数说明②构…

【无人机】低空经济中5G RedCap芯片的技术分析报告

1. 引言 图一. 新基建&#xff1a;低空经济 低空经济作为一种新兴的经济形态&#xff0c;涵盖了无人机、电动垂直起降飞行器&#xff08;eVTOL&#xff09;、低空物流、空中交通管理等多个领域。随着5G网络的普及和演进&#xff0c;5G RedCap&#xff08;Reduced Capability&a…