CCF-交通规划-dijkstra+贪心
交通规划
1 2 4
1 3 5
2 3 2
2 4 3
3 4 2
解题思路:
在dijkstra求单源点路径最短的情况下实现最小花费
代码如下:
1 #include <iostream>
2 #include <queue>
3 #include <vector>
4
5 #define NMAX 10005
6 #define INTMAX 0x7fffffff
7
8 using namespace std;
9
10 // v表示节点,cost表示出发点到v点的距离
11 struct Node {
12 int v;
13 int cost;
14 Node(int vv = 0, int c = 0) {
15 v = vv, cost = c;
16 }
17 // 优先队列将按距离从小到大排列
18 friend bool operator<(Node n1, Node n2) {
19 return n1.cost > n2.cost;
20 }
21 };
22
23 // v表示边的另一端节点,cost表示该边的权重
24 struct Edge {
25 int v;
26 int cost;
27 Edge(int vv = 0, int c = 0) {
28 v = vv, cost = c;
29 }
30 };
31
32 vector<Edge>G[NMAX]; // 无向图
33 bool marked[NMAX]; // D算法中每个顶点仅处理一遍
34 int disto[NMAX]; // 出发点到某点距离
35 int costo[NMAX]; // 接通该点需要增加的边的权重
36 int N, M;
37
38 void dijkstra(int s) {
39 for (int i = 0; i <= N; i++) {
40 costo[i] = disto[i] = INTMAX;//初始化
41 marked[i] = false;
42 }
43 disto[s] = 0;
44 costo[s] = 0;
45 priority_queue<Node>pq; // 保存<v,disto[v]>且按disto[v]升序排列
46 pq.push(Node(s, 0));
47 marked[0]=true;
48
49 Node tmp;
50 while (!pq.empty()) {
51 tmp = pq.top();
52 pq.pop();
53 int v = tmp.v;
54 if (!marked[v]) {
55 marked[v]=true;
56 int len = G[v].size();
57 for (int i = 0; i < len; i++) {
58 int vv = G[v][i].v;
59 if(marked[vv])
60 continue;
61 int cost = G[v][i].cost;
62 int newdist = disto[v] + cost;
63 if (disto[vv] > newdist) {
64 disto[vv] = newdist;
65 costo[vv] = cost; // 增加的内容
66 pq.push(Node(vv, disto[vv]));
67 }
68 // 加入点vv时若出现多种距离相同的方案,选取新边最小那个
69 if (disto[vv] == newdist) {
70 costo[vv] = min(costo[vv], cost);
71 }
72 }
73 }
74 }
75 }
76
77 int main(void) {
78 cin >> N >> M;
79
80 int s, e, c;
81 for (int i = 0; i < M; i++) {
82 cin >> s >> e >> c;
83 G[s].push_back(Edge(e, c));//无线图中添加边
84 G[e].push_back(Edge(s, c));
85 }
86 dijkstra(1);
87
88 // 统计边权重
89 int res = 0;
90 for (int i = 2; i <= N; i++) {
91 res += costo[i];
92 }
93 cout << res << endl;
94
95 return 0;
96 }
ps:相关资料来自于网上
CCF-交通规划-dijkstra+贪心的更多相关文章
- CCF 交通规划(Dijkstra+优先队列)
交通规划 问题描述 G国国王来中国参观后,被中国的高速铁路深深的震撼,决定为自己的国家也建设一个高速铁路系统. 建设高速铁路投入非常大,为了节约建设成本,G国国王决定不新建铁路,而是将已有的铁路改造成 ...
- ccf交通规划
一.试题 问题描述 G国国王来中国参观后,被中国的高速铁路深深的震撼,决定为自己的国家也建设一个高速铁路系统. 建设高速铁路投入非常大,为了节约建设成本,G国国王决定不新建铁路,而是将已有的铁路改 ...
- CCF 201609-4 交通规划
问题描述 试题编号: 201609-4 试题名称: 交通规划 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 G国国王来中国参观后,被中国的高速铁路深深的震撼,决定为自己的国家 ...
- CCF CSP 201609-4 交通规划
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201609-4 交通规划 问题描述 G国国王来中国参观后,被中国的高速铁路深深的震撼,决定为自 ...
- NYOJ 203 三国志(Dijkstra+贪心)
三国志 时间限制:3000 ms | 内存限制:65535 KB 难度:5 描写叙述 <三国志>是一款非常经典的经营策略类游戏.我们的小白同学是这款游戏的忠实玩家.如今他把游戏简化一下 ...
- 【CCF】交通规划 Dijstra变形 优先级队列重载
[题意] 给定一个无向图,求这个图满足所有点到顶点的最短路径不变的最小生成树 [AC] 注意双向边要开2*maxm 注意优先级队列 参考https://www.cnblogs.com/cielosun ...
- 4.23 子集 分数规划 二分 贪心 set 单峰函数 三分
思维题. 显然考虑爆搜.然后考虑n^2能做不能. 容易想到枚举中间的数字mid 然后往mid两边加数字 使其整个集合权值最大. 这里有一个比较显然的贪心就不再赘述了. 可以发现这样做对于集合是奇数的时 ...
- js算法初窥05(算法模式02-动态规划与贪心算法)
在前面的文章中(js算法初窥02(排序算法02-归并.快速以及堆排)我们学习了如何用分治法来实现归并排序,那么动态规划跟分治法有点类似,但是分治法是把问题分解成互相独立的子问题,最后组合它们的结果,而 ...
- 交通规划_dijkstra
问题描述 G国国王来中国参观后,被中国的高速铁路深深的震撼,决定为自己的国家也建设一个高速铁路系统. 建设高速铁路投入非常大,为了节约建设成本,G国国王决定不新建铁路,而是将已有的铁路改造成高速铁路. ...
随机推荐
- Java并发包源码学习系列:AbstractQueuedSynchronizer
目录 本篇学习目标 AQS概述 AbstractOwnableSynchronizer 同步队列与Node节点 同步状态state 重要方法分析 独占式获取与释放同步状态 共享式获取与释放同步状态 A ...
- 达梦数据库学习(一、linux操作系统安装及数据库安装)
达梦数据库学习(一.linux操作系统安装及数据库安装) 环境介绍: 使用VM12+中标麒麟V7.0操作系统+达梦8数据库 一.linux系统搭建 本部分没有需要着重介绍,注意安装时基本环境选择&qu ...
- CPU性能测试——CoreMark篇
本文将介绍使用CoreMark测试程序对我们小组自研芯片进行性能的测试,记录了CoreMarK工具的使用以及对其测试结果进行分析 测试环境: PC OS: Ubuntu20.04 LTS CPU: 自 ...
- idea破解方式:永久激活
相信很多小伙伴都发现了,每年到年底的时候,idea注册码都大面积的失效,早上到办公室打开电脑发现注册码过期,还要花很长时间找新的: 这里介绍两种破解方式,都是有生之年不到期:与网上现有的方式基本一致. ...
- 洛谷 P4396 [AHOI2013]作业
题目描述 题目传送门 分析 因为询问是关于区间的,并且没有强制在线,所以能用莫队解决 但是还要支持查询区间内大于等于 \(a\),小于等于 \(b\) 的数的个数和数值的个数 所以还要套一个数据结构 ...
- Mac上“您没有权限来打开应用程序”(Big Sur)
最近电脑更新了Macos的最新11版大苏尔 Big Sur.很快问题就出现了:安装某个软件的时候Key Gen打不开,提示您没有权限来打开应用程序,类似这样:https://zhuanlan.zhih ...
- js如何替换字符串中匹配到多处中某一指定节点?
抛出一个问题,如图,搜索关键字,匹配到四处,那我鼠标放在第二处,我想把它变个颜色,该怎么实现呢?回到文章的标题,js如何替换字符串中匹配到多处中某一指定节点? 字符串的替换,我们首先想到的一个属性是r ...
- 虚拟机Linux安装Oracle容器并实现局域网其他主机访问查询
该文涉及Docker下Oracle容器的安装,主机端口的设置实现局域网内终端均能连接上Oracle数据库,图解如下: 一.关于Docker安装oracle容器可以参考下面博文: https://blo ...
- synchronized的jvm源码分析聊锁的意义
上篇写完了ReentrantLock源码实现,从我们的角度分析设计锁,在对比大神的实现,顺道拍了一波道哥的马屁,虽然他看不到,哈哈.这一篇我们来聊一聊synchronized的源码实现,并对比reen ...
- 【WPF】将DataGrid内容导出到Excel
引言 在做项目时要求将datagrid的内容导出到Excel,以前做winform项目时遇到过,就把代码搬过来用,但wpf和winform还是有些不同,就修改了一些东西,使其能实现这个功能. 本文是导 ...