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国国王决定不新建铁路,而是将已有的铁路改造成高速铁路. ...
随机推荐
- node实现文件下载
1.引入fs const fs = require('fs') const path = reqire('path') 2.方法 const downloadFile = function (dest ...
- Go GRPC 入门(二)
前言 最近较忙,其实准备一篇搞定的 中途有事,只能隔了一天再写 正文 pb.go 需要注意的是,在本个 demo 中,客户端与服务端都是 Golang,所以在客户端与服务端都公用一个 pb.go 模板 ...
- 【C++】《C++ Primer 》第十六章
第十六章 模板与泛型编程 面向对象编程和泛型编程都能处理在编写程序时不知道类型的情况. OOP能处理类型在程序允许之前都未知的情况. 泛型编程在编译时就可以获知类型. 一.定义模板 模板:模板是泛型编 ...
- PAT甲级 Perfect Sequence (25) 记忆化搜索
题目分析: 意思是要求对于一个给出的数组,我们在其中尽可能多选数字,使得所选数字的max <= min * p,而由于数据量较大直接二层循环不加优化实现是不现实的,由题意得知,对于数字序列的子序 ...
- Assuming that agent dropped connection because of access permission
Assuming that agent dropped connection because of access permission
- 【高级排序算法】1、归并排序法 - Merge Sort
归并排序法 - Merge Sort 文章目录 归并排序法 - Merge Sort nlogn 比 n^2 快多少? 归并排序设计思想 时间.空间复杂度 归并排序图解 归并排序描述 归并排序小结 参 ...
- ps的参数解释
[root@bogon ~]# ps axuUSER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND user启动进程的用户 pid 表示进程标志 ...
- show engine innodb status
TRANSACTIONS------------Trx id counter 2003909(当前事务号)Purge done for trx's n:o < 2003905 (清理线程完成到了 ...
- RSA共模攻击
在安恒月赛中碰到一道密码学方向的ctf题 附上源码 from flag import flag from Crypto.Util.number import * p=getPrime(1024) q= ...
- Cookie&Session&Jsp总结
知识点梳理 Cookie&Session&Jsp 1 会话技术 1.1 会话管理概述 1.1.1 会话技术介绍 会话:浏览器和服务器之间的多次请求和响应 (一次对话) 为了实现一些功能 ...