问题描述

试题编号: 201609-4
试题名称: 交通规划
时间限制: 1.0s
内存限制: 256.0MB
问题描述:
问题描述
  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结点开始往外扩展,每扩展一个结点刚好就要多修一条高速铁路,因此在做求解最短路时,可以记录下每个结点扩展时所需要多修建的这条高速铁路的长度,在扩展时遇到有多种可能的最短路情况时,记录下边权最小的一个。
 
代码如下:
  1. #include<bits/stdc++.h>
  2. using namespace std;
  3.  
  4. const int MAX=;
  5. const int INF=1e9;
  6. int n,m;
  7.  
  8. struct HeapNode
  9. {
  10. int d,u;
  11. bool operator<(const HeapNode& r)const
  12. {
  13. return d>r.d;
  14. }
  15. };
  16.  
  17. struct Edge
  18. {
  19. int to,dis;
  20. };
  21.  
  22. vector<Edge>G[MAX];
  23. int d[MAX];
  24. bool vis[MAX];
  25.  
  26. int cost [MAX];
  27. void dijkstra(int s)
  28. {
  29. priority_queue<HeapNode>Q;
  30. for(int i=;i<=n;i++)
  31. d[i]=cost[s]=INF;
  32. d[s]=cost[s]=;
  33. memset(vis,,sizeof vis);
  34.  
  35. Q.push({,s});
  36.  
  37. while(!Q.empty())
  38. {
  39. HeapNode x=Q.top();
  40. Q.pop();
  41.  
  42. int u=x.u;
  43.  
  44. if(vis[u])
  45. continue;
  46. vis[u]=true;
  47.  
  48. for(int i=;i<G[u].size();i++)
  49. {
  50. Edge& e=G[u][i];
  51. if(d[e.to]>d[u]+e.dis)
  52. {
  53. d[e.to]=d[u]+e.dis;
  54. Q.push({d[e.to],e.to});
  55. cost[e.to]=e.dis;
  56. }
  57. //记录下边权最小的一个
  58. if(d[e.to]==d[u]+e.dis&&cost[e.to]>e.dis)
  59. cost[e.to]=e.dis;
  60. }
  61. }
  62. }
  63.  
  64. int main()
  65. {
  66. scanf("%d%d",&n,&m);
  67. for(int i=;i<m;i++)
  68. {
  69. int a,b,c;
  70. scanf("%d%d%d",&a,&b,&c);
  71. G[a].push_back({b,c});
  72. G[b].push_back({a,c});
  73. }
  74.  
  75. dijkstra();
  76. int ans=;
  77. for(int i=;i<=n;i++)
  78. ans+=cost[i];
  79.  
  80. printf("%d\n",ans);
  81.  
  82. return ;
  83. }
 

CCF 201609-4 交通规划的更多相关文章

  1. CCF CSP 201609-4 交通规划

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

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

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

  3. ccf交通规划

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

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

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

  5. 交通规划_dijkstra

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

  6. CCF-CSP题解 201609-4 交通规划

    最小最短路径树. \(dis[j]==dis[i]+w(i,j)\)时,从\(w(i,j')\)和\(w(i,j)\)考虑.--从0分到100分. #include <bits/stdc++.h ...

  7. CCF_201612-4_交通规划

    http://115.28.138.223/view.page?gpid=T44 好像也没想象中的那么难,没办法,当初连个优先队列dij都不会写= = 在优先队列dij算法上加上相等的时候的处理就可以 ...

  8. CSP-201609-4 交通规划

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

  9. CCF计算机职业资格认证考试题解

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF计算机职业资格认证考试题解 CCF计算机软件能力认证(简称CCF CSP认证)是CCF计算机职业资格认证系 ...

随机推荐

  1. gulp源码解析(二)—— vinyl-fs

    在上一篇文章我们对 Stream 的特性及其接口进行了介绍,gulp 之所以在性能上好于 grunt,主要是因为有了 Stream 助力来做数据的传输和处理. 那么我们不难猜想出,在 gulp 的任务 ...

  2. js之Math对象

    ; var num1 = Math.floor(num); // 向下取整 var num2 = Math.ceil(num); // 向上取整 document.write(num2+'-<b ...

  3. iOS ReactiveCocoa(RAC)学习详解

    概述: ReactiveCocoa(简称为RAC),是由Github开源的一个应用于iOS和OS开发的一个框架,有时间,自己也了解学习了一下这个框架的一些基本的应用,其实你要学的话网上是有很多很多的博 ...

  4. 安卓TCP通信版本2

    PC做服务器,安卓做客户端. 安卓获取输入框的内容并发送,然后等待接收服务器的消息 服务器先行开启,接收到客户端的数据,然后回复消息. 实现了对线程类的封装,通过按钮启动线程发送并接收 服务器代码(j ...

  5. C语言一维数组复制

    /* * 通过自定义的函数memcpy实现复制功能,优点是不需要引用库函数 * 在windows平台下,通过sizeof测试发现: int 4字节 float 4字节 double 8字节 */ #i ...

  6. (转)java二维数组的深度学习(静态与动态)

    转自:http://developer.51cto.com/art/200906/128274.htm,谢谢 初始化: 1.动态初始化:数组定义与为数组分配空间和赋值的操作分开进行:2.静态初始化:在 ...

  7. (@WhiteTaken)设计模式学习——原型模式

    有这样一个需求,两个对象,只是名称以及其他几个属性不一样,而其他的大部分的属性都是相同的. 这时候我们可以用到原型模式,也就是克隆模式. 原型模式:原型模式是一个对象创建型模式,通过克隆原对象,可以使 ...

  8. spring入门--Spring框架底层原理

    上一篇的博客,我们可以看出来,spring可以维护各个bean (对象),并向其中注入属性值.那么,如果们要把一个对象的引用注入另外一个对象呢?应该怎么处理呢? 我们知道,对于对象中的属性来说,我们注 ...

  9. MyBatis 源码分析——生成Statement接口实例

    JDBC的知识对于JAVA开发人员来讲在简单不过的知识了.PreparedStatement的作用更是胸有成竹.我们最常见用到有俩个方法:executeQuery方法和executeUpdate方法. ...

  10. Extjs mvc

    MVC的模式,模型(Models)和控制器(Controllers) Model模型 是字段和它们的数据的集合,例如User模型带有username和password字段,模型知道如何持久化自己的数据 ...