交通规划

问题描述
  G国国王来中国参观后,被中国的高速铁路深深的震撼,决定为自己的国家也建设一个高速铁路系统。   建设高速铁路投入非常大,为了节约建设成本,G国国王决定不新建铁路,而是将已有的铁路改造成高速铁路。现在,请你为G国国王提供一个方案,将现有的一部分铁路改造成高速铁路,使得任何两个城市间都可以通过高速铁路到达,而且从所有城市乘坐高速铁路到首都的最短路程和原来一样长。请你告诉G国国王在这些条件下最少要改造多长的铁路。
输入格式
  输入的第一行包含两个整数n, m,分别表示G国城市的数量和城市间铁路的数量。所有的城市由1到n编号,首都为1号。   接下来m行,每行三个整数a, b, c,表示城市a和城市b之间有一条长度为c的双向铁路。这条铁路不会经过a和b以外的城市。
输出格式
  输出一行,表示在满足条件的情况下最少要改造的铁路长度。
样例输入
4 5
1 2 4
1 3 5
2 3 2
2 4 3
3 4 2
样例输出
11
评测用例规模与约定
  对于20%的评测用例,1 ≤ n ≤ 10,1 ≤ m ≤ 50;   
      对于50%的评测用例,1 ≤ n ≤ 100,1 ≤ m ≤ 5000;   
      对于80%的评测用例,1 ≤ n ≤ 1000,1 ≤ m ≤ 50000;   
      对于100%的评测用例,1 ≤ n ≤ 10000,1 ≤ m ≤ 100000,1 ≤ a, b ≤ n,1 ≤ c ≤ 1000。输入保证每个城市都可以通过铁路达到首都。
 

解题思路:

在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+贪心的更多相关文章

  1. CCF 交通规划(Dijkstra+优先队列)

    交通规划 问题描述 G国国王来中国参观后,被中国的高速铁路深深的震撼,决定为自己的国家也建设一个高速铁路系统. 建设高速铁路投入非常大,为了节约建设成本,G国国王决定不新建铁路,而是将已有的铁路改造成 ...

  2. ccf交通规划

    一.试题 问题描述  G国国王来中国参观后,被中国的高速铁路深深的震撼,决定为自己的国家也建设一个高速铁路系统.  建设高速铁路投入非常大,为了节约建设成本,G国国王决定不新建铁路,而是将已有的铁路改 ...

  3. CCF 201609-4 交通规划

    问题描述 试题编号: 201609-4 试题名称: 交通规划 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 G国国王来中国参观后,被中国的高速铁路深深的震撼,决定为自己的国家 ...

  4. CCF CSP 201609-4 交通规划

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201609-4 交通规划 问题描述 G国国王来中国参观后,被中国的高速铁路深深的震撼,决定为自 ...

  5. NYOJ 203 三国志(Dijkstra+贪心)

    三国志 时间限制:3000 ms  |  内存限制:65535 KB 难度:5 描写叙述 <三国志>是一款非常经典的经营策略类游戏.我们的小白同学是这款游戏的忠实玩家.如今他把游戏简化一下 ...

  6. 【CCF】交通规划 Dijstra变形 优先级队列重载

    [题意] 给定一个无向图,求这个图满足所有点到顶点的最短路径不变的最小生成树 [AC] 注意双向边要开2*maxm 注意优先级队列 参考https://www.cnblogs.com/cielosun ...

  7. 4.23 子集 分数规划 二分 贪心 set 单峰函数 三分

    思维题. 显然考虑爆搜.然后考虑n^2能做不能. 容易想到枚举中间的数字mid 然后往mid两边加数字 使其整个集合权值最大. 这里有一个比较显然的贪心就不再赘述了. 可以发现这样做对于集合是奇数的时 ...

  8. js算法初窥05(算法模式02-动态规划与贪心算法)

    在前面的文章中(js算法初窥02(排序算法02-归并.快速以及堆排)我们学习了如何用分治法来实现归并排序,那么动态规划跟分治法有点类似,但是分治法是把问题分解成互相独立的子问题,最后组合它们的结果,而 ...

  9. 交通规划_dijkstra

    问题描述 G国国王来中国参观后,被中国的高速铁路深深的震撼,决定为自己的国家也建设一个高速铁路系统. 建设高速铁路投入非常大,为了节约建设成本,G国国王决定不新建铁路,而是将已有的铁路改造成高速铁路. ...

随机推荐

  1. Java并发包源码学习系列:AbstractQueuedSynchronizer

    目录 本篇学习目标 AQS概述 AbstractOwnableSynchronizer 同步队列与Node节点 同步状态state 重要方法分析 独占式获取与释放同步状态 共享式获取与释放同步状态 A ...

  2. 达梦数据库学习(一、linux操作系统安装及数据库安装)

    达梦数据库学习(一.linux操作系统安装及数据库安装) 环境介绍: 使用VM12+中标麒麟V7.0操作系统+达梦8数据库 一.linux系统搭建 本部分没有需要着重介绍,注意安装时基本环境选择&qu ...

  3. CPU性能测试——CoreMark篇

    本文将介绍使用CoreMark测试程序对我们小组自研芯片进行性能的测试,记录了CoreMarK工具的使用以及对其测试结果进行分析 测试环境: PC OS: Ubuntu20.04 LTS CPU: 自 ...

  4. idea破解方式:永久激活

    相信很多小伙伴都发现了,每年到年底的时候,idea注册码都大面积的失效,早上到办公室打开电脑发现注册码过期,还要花很长时间找新的: 这里介绍两种破解方式,都是有生之年不到期:与网上现有的方式基本一致. ...

  5. 洛谷 P4396 [AHOI2013]作业

    题目描述 题目传送门 分析 因为询问是关于区间的,并且没有强制在线,所以能用莫队解决 但是还要支持查询区间内大于等于 \(a\),小于等于 \(b\) 的数的个数和数值的个数 所以还要套一个数据结构 ...

  6. Mac上“您没有权限来打开应用程序”(Big Sur)

    最近电脑更新了Macos的最新11版大苏尔 Big Sur.很快问题就出现了:安装某个软件的时候Key Gen打不开,提示您没有权限来打开应用程序,类似这样:https://zhuanlan.zhih ...

  7. js如何替换字符串中匹配到多处中某一指定节点?

    抛出一个问题,如图,搜索关键字,匹配到四处,那我鼠标放在第二处,我想把它变个颜色,该怎么实现呢?回到文章的标题,js如何替换字符串中匹配到多处中某一指定节点? 字符串的替换,我们首先想到的一个属性是r ...

  8. 虚拟机Linux安装Oracle容器并实现局域网其他主机访问查询

    该文涉及Docker下Oracle容器的安装,主机端口的设置实现局域网内终端均能连接上Oracle数据库,图解如下: 一.关于Docker安装oracle容器可以参考下面博文: https://blo ...

  9. synchronized的jvm源码分析聊锁的意义

    上篇写完了ReentrantLock源码实现,从我们的角度分析设计锁,在对比大神的实现,顺道拍了一波道哥的马屁,虽然他看不到,哈哈.这一篇我们来聊一聊synchronized的源码实现,并对比reen ...

  10. 【WPF】将DataGrid内容导出到Excel

    引言 在做项目时要求将datagrid的内容导出到Excel,以前做winform项目时遇到过,就把代码搬过来用,但wpf和winform还是有些不同,就修改了一些东西,使其能实现这个功能. 本文是导 ...