当前位置: 首页 > news >正文

P12874 [蓝桥杯 2025 国 Python A] 巡逻||题解||图论

题目链接

题解:
首先,我们需要考虑一下整个是一颗树,输入的是起点到终点,还有起点到终点的危险值,算出固定长度下所有路的风险值的总和。

所以直接遍历这棵树,遍历每一个点,1到N,用深搜,一段路长度达到 k 就结束,不够也要结束,为了防止重复,还得开一个布尔数组,防止走回头路,走过的要进行标记已走过,没有走过的要标记未走过。

然后,我们要考虑用什么来存储树的节点,一般存子节点和父节点,我们会采用vector<int>e[N],用序号表示父节点,值来表示子节点,这样子不断去遍历

但是,这个题目还需要存储危险值,所以我们可以用结构体直接存储这三个值,或者用向量结构体去存储(具体看代码)

最后,注意数据范围,首先看n的范围到了5000,单个危险值的范围到达10的6次方,危险值的总和范围会超过了Int的范围,所以最后算总和的变量要开范围到long long.

代码如下:

#include <bits/stdc++.h>
using namespace std;
int n, k, x, y, z;
long long allsum = 0;
const int N = 1e6;struct Node {int end;int wei;//终点节点,危险值
};
vector<Node>tree[N];
//开始节点
//不能走回头路,所以需要标记是否走过
bool vis[N];void dfs(int deep, int sum, int length) {if (length == k) {//到特地的长度,就可以返回了//也可以加
//		sum+=tree[deep].wei;allsum += sum;return;}//如果还没到长度//遍历该节点的子节点for (auto &t : tree[deep]) {//如果走过的路就跳过if (vis[t.end]) {continue;}
//		sum += t.wei;vis[t.end] = 1;dfs(t.end, sum + t.wei, length + 1);vis[t.end] = 0;}return;}int main() {cin >> n >> k;for (int i = 2; i <= n; i++) {cin >> x >> y >> z;//因为需要反过来经过道路也可以正向经过道路//道路没有箭头tree[x].push_back({y, z});tree[y].push_back({x, z});//所以需要双向存储,存储两次开头和终点}for (int i = 1; i <= n; i++) {vis[i] = 1;dfs(i, 0, 0);vis[i] = 0;}cout << allsum ;return 0;
}

这里是红糖,记录我的小白进化史。

希望能帮到你们,创作不易,如果觉得有帮助可以为我点个赞!!

http://www.dtcms.com/a/494662.html

相关文章:

  • 律师在哪个网站做国家企业信用系统官网
  • mapbox基础,栅格图片切片并发布、加载
  • 深入 RFC 793:TCP 报文头部、MSS 协商与三次握手 / 四次挥手全解析
  • deconv(多项式除法)
  • unitree rl gym项目实践记录2:通过TensorBoard查看奖励曲线
  • 2.8、权限的终极目标:提权与持久化
  • 模式识别与机器学习课程笔记(11):深度学习
  • 网站流量站怎么做WordPress的登录页面
  • leetcode 191. 位1的个数 python
  • 河北住房与城乡建设部网站北京做网站企业
  • WordPress网站转APP插件家具设计
  • docker 学习dockerfile 构建 Nginx 镜像-部署 nginx 静态网
  • Prompt Engineering 核心知识:从基础模式到思维链,掌握大模型高效交互秘籍
  • Android中加载unity aar包实现方案
  • auxiliary英文单词学习
  • Elasticsearch:创建一个定制的 DeepSeek 嵌入推理端点
  • “自然搞懂”深度学习系列(基于Pytorch架构)——01初入茅庐
  • 51c~Pytorch~合集6
  • Java 对接印度股票数据源实现 http+ws实时数据
  • 建设网站分析报告陕西四通建设工程有限责任公司网站
  • 微信网站建设app公司WordPress邮箱注册慢
  • 【Qt】元对象系统:从实际开发中看QML/C++交互原理
  • 【MySQL】从零开始了解数据库开发 --- 数据表的索引
  • 设计模式篇之 策略模式 Strategy
  • 【HarmonyOS】并发线程间的通信
  • 2三、buildroot
  • 开源 C++ QT QML 开发(二十二)多媒体--ffmpeg编码和录像
  • 详细分析平衡树--红黑树(万字长文/图文详解)
  • 国产开源代码管理工具 GitPuk 安装+入门全流程解析
  • wordpress本地视频教程免费网站seo优化