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并发包源码学习系列:CLH同步队列及同步资源获取与释放
目录 本篇学习目标 CLH队列的结构 资源获取 入队Node addWaiter(Node mode) 不断尝试Node enq(final Node node) boolean acquireQue ...
- DHCP.md
DHCP 主配置文件 从 /usr/share/doc/dhcp 复制 dhcpd.conf.sample 到/etc/dhcp下 ...
- 使用Pr压缩视频,增大音量
视屏压缩(亲测有效教程):https://www.zhihu.com/question/67762625 音量增大(亲测有效教程):https://jingyan.baidu.com/article/ ...
- 浅谈TypeScript,配置文件以及数据类型
TypeScript在javaScript基础上多了一些拓展特性,多出来的是一些类型系统以及对ES6新特性的支持最终会编译成原始的javaScript, 文件名以.ts结尾,编译过后.js结尾,在an ...
- 【JavaWeb】JSP 页面
JSP 页面 简介 JSP(Java Server Pages),即 Java 的服务器页面.它的主要作用是代替 Servlet 程序回传 HTML 页面的数据,因为 Servlet 程序回传 HTM ...
- SpringBoot配置文件(1)
配置文件 1.配置文件 SpringBoot使用一个全局的配置文件 application.properties application.yml 配置文件名是固定的: 他的作用是修改SpringBoo ...
- 拍摄、剪辑vlog的思路
这篇文章是看了很多狂阿弥_ 的作品后 产生的一些小小总结.这些技法只是锦上添花,阿弥作品真正好的地方在于他细腻的情感,真实的对白,和打动人心的满分作文. 优秀的Vlog ,在于它和观众产生的情感共鸣. ...
- Python基础语法4-运算符
Python提供了一系列丰富的运算符,包括: Ø算术运算符 Ø赋值运算符 Ø关系运算符 Ø逻辑运算符 Ø位运算符 Ø三元运算符 Ø身份运算符 Ø成员运算符
- 2019 Java开发利器Intellij IDEA安装、配置和使用
进入Intellij IDEA的官网,选择电脑对应的合适版本进行下载,这儿我选择的是Intellij IDEA的社区版,安装旗舰版可去网上找相应的教程. Intellij IDEA的官网:https: ...
- egret 解决游戏loading前的黑屏
一.问题 egret游戏loading界面的制作可以参考这个,我就不多赘述啦,步骤也比较详细<Egret制作Loading页面及分步加载资源教程>. 后面我发现即便加上loading,在游 ...