A. 最短路

Time Limit: 1000ms
Memory Limit: 32768KB

64-bit integer IO format: %I64d      Java class name: Main

在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt。但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以现在他们想要寻找最短的从商店到赛场的路线,你可以帮助他们吗?

Input

输入包括多组数据。每组数据第一行是两个整数N、M(N<=100,M<=10000),N表示成都的大街上有几个路口,标号为1的路口是商店所在地,标号为N的路口是赛场所在地,M则表示在成都有几条路。N=M=0表示输入结束。接下来M行,每行包括3个整数A,B,C(1<=A,B<=N,1<=C<=1000),表示在路口A与路口B之间有一条路,我们的工作人员需要C分钟的时间走过这条路。
输入保证至少存在1条商店到赛场的路线。

Output

对于每组输入,输出一行,表示工作人员从商店走到赛场的最短时间

Sample Input

2 1
1 2 3
3 3
1 2 5
2 3 5
3 1 2
0 0

Sample Output

3
2

解题:最短路。。。

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <cmath>
 5 #include <algorithm>
 6 #include <climits>
 7 #include <vector>
 8 #include <queue>
 9 #include <cstdlib>
10 #include <string>
11 #include <set>
12 #define LL long long
13 #define INF 0x3f3f3f
14 using namespace std;
15 int mp[110][110],d[110],n,m;
16 bool vis[110];
17 void dij(){
18     int i,j,theMin,index;
19     for(i = 0; i <= n; i++)
20         d[i] = INF>>1;
21     d[1] = 0;
22     memset(vis,false,sizeof(vis));
23     for(i = 0; i < n; i++){
24         theMin = INF;
25         for(j = 1; j <= n; j++){
26             if(!vis[j] && theMin > d[j]) theMin = d[index = j];
27         }
28         vis[index] = true;
29         if(index == n) break;
30         for(j = 1; j <= n; j++){
31             if(!vis[j] && d[j] > d[index]+mp[index][j])
32                 d[j] = d[index] + mp[index][j];
33         }
34     }
35 }
36 int main(){
37     int i,j,u,v,w;
38     while(scanf("%d%d",&n,&m),n||m){
39         for(i = 0; i <= n; i++)
40         for(j = 0; j <= n; j++)
41             mp[i][j] = INF;
42         for(i = 0; i < m; i++){
43             scanf("%d%d%d",&u,&v,&w);
44             mp[u][v] = mp[v][u] = w;
45         }
46         dij();
47         printf("%d\n",d[n]);
48     }
49     return 0;
50 }

View Code

优先队列版Dijkstra

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <cstdlib>
 5 #include <vector>
 6 #include <queue>
 7 #include <climits>
 8 #include <algorithm>
 9 #include <cmath>
10 #define LL long long
11 #define INF 0x3f3f3f
12 using namespace std;
13 #define pii pair<int,int>
14 const int maxn = 102;
15 struct arc {
16     int to,w;
17 };
18 int n,m;
19 vector<arc>g[maxn];
20 bool done[maxn];
21 int d[maxn];
22 priority_queue<pii,vector< pii >,greater< pii > >q;
23 void dj() {
24     int i,j;
25     for(i = 1; i <= n; i++) {
26         done[i] = false;
27         d[i] = INF;
28     }
29     d[1] = 0;
30     while(!q.empty()) q.pop();
31     q.push(make_pair(d[0],1));
32     while(!q.empty()) {
33         pii u =q.top();
34         q.pop();
35         int x = u.second;
36         if(done[x]) continue;
37         done[x] = true;
38         for(i = 0; i < g[x].size(); i++) {
39             j = g[x][i].to;
40             if(d[j] > d[x] + g[x][i].w) {
41                 d[j] = d[x]+g[x][i].w;
42                 q.push(make_pair(d[j],j));
43             }
44         }
45     }
46
47 }
48 int main() {
49     int i,j,u,v,w;
50     while(scanf("%d%d",&n,&m),n||m) {
51         for(i = 1; i <= n; i++)
52             g[i].clear();
53         for(i = 0; i < m; i++) {
54             scanf("%d%d%d",&u,&v,&w);
55             g[u].push_back((arc) {v,w});
56             g[v].push_back((arc) {u,w});
57         }
58         dj();
59         printf("%d\n",d[n]);
60     }
61     return 0;
62 }

View Code

Bellman—Ford算法:

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <cstdlib>
 5 #include <vector>
 6 #include <queue>
 7 #include <climits>
 8 #include <algorithm>
 9 #include <cmath>
10 #define LL long long
11 #define INF 0x3f3f3f
12 using namespace std;
13 #define pii pair<int,int>
14 const int maxn = 10010;
15 struct arc {
16     int u,v,w;
17 } g[maxn];
18 int n,m,cnt;
19 int d[maxn];
20 void bf() {
21     int i,j;
22     for(i = 1; i <= n; i++)
23         d[i] = INF;
24     d[1] = 0;
25     bool flag;
26     for(i = 1; i < n; i++) {
27         flag = true;
28         for(j = 0; j < cnt; j++)
29             if(d[g[j].v] > d[g[j].u]+g[j].w){
30                  d[g[j].v] = d[g[j].u]+g[j].w;
31                  flag = false;
32             }
33         if(flag) break;
34     }
35 }
36 int main() {
37     int i,u,v,w;
38     while(scanf("%d%d",&n,&m),n||m) {
39         for(cnt = i = 0; i < m; i++) {
40             scanf("%d%d%d",&u,&v,&w);
41             g[cnt++] = (arc) {u,v,w};
42             g[cnt++] = (arc) {v,u,w};
43         }
44         bf();
45         printf("%d\n",d[n]);
46     }
47     return 0;
48 }

View Code

spfa算法版:

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <cstdlib>
 5 #include <vector>
 6 #include <queue>
 7 #include <climits>
 8 #include <algorithm>
 9 #include <cmath>
10 #define LL long long
11 #define INF 0x3f3f3f
12 using namespace std;
13 #define pii pair<int,int>
14 const int maxn = 1001;
15 struct arc {
16     int to,w;
17 };
18 vector<arc>g[maxn];
19 queue<int>q;
20 int n,m,d[maxn];
21 bool done[maxn];
22 void spfa() {
23     int i,j;
24     for(i = 1; i <= n; i++){
25         d[i] = INF;
26         done[i] = false;
27     }
28     d[1] = 0;
29     while(!q.empty()) q.pop();
30     done[1] = true;
31     q.push(1);
32     while(!q.empty()){
33         int temp = q.front();
34         q.pop();
35         done[temp] = false;
36         for(i = 0; i < g[temp].size(); i++){
37             j = g[temp][i].to;
38             if(d[j] > d[temp]+g[temp][i].w){
39                 d[j] = d[temp]+g[temp][i].w;
40                 if(!done[j]){
41                     q.push(j);
42                     done[j] = true;
43                 }
44             }
45         }
46     }
47
48 }
49 int main() {
50     int i,u,v,w;
51     while(scanf("%d%d",&n,&m),n||m) {
52         for(i = 1; i <= n; i++)
53             g[i].clear();
54         for(i = 0; i < m; i++) {
55             scanf("%d%d%d",&u,&v,&w);
56             g[u].push_back((arc){v,w});
57             g[v].push_back((arc){u,w});
58         }
59         spfa();
60         printf("%d\n",d[n]);
61     }
62     return 0;
63 }

View Code

转载于:https://www.cnblogs.com/crackpotisback/p/3858673.html

图论trainning-part-1 A. 最短路相关推荐

  1. 图论 ---- F. The Shortest Statement (最短路的性质 + 任意两点间最短路 + 图转树)

    题目链接 题目大意: 给你一个nnn个点mmm条边的无向图,就是动态询问任意两点间的最短路 n,m∈[1,1e5],m−n≤20n,m\in[1,1e5],m-n\leq20n,m∈[1,1e5],m ...

  2. 【图论专题】单源最短路的扩展应用

    题目列表: 题目 算法 AcWing 1137. 选择最佳线路 最短路+超级源点 AcWing 1131. 拯救大兵瑞恩 拆点建图+思维+双端队列BFS+状态压缩 AcWing 1134. 最短路计数 ...

  3. 【图论专题】单源最短路的综合应用

    单源最短路径经常与DFS.DP.二分.拓扑排序等算法的结合使用. 题目列表: 题目 算法 AcWing 1135. 新年好 最短路+DFS AcWing 340. 通信线路 二分+双端队列BFS Ac ...

  4. 数据结构实验之图论七:驴友计划(最短路Floyd/Dijkstra)

    Description 做为一个资深驴友,小新有一张珍藏的自驾游线路图,图上详细的标注了全国各个城市之间的高速公路距离和公路收费情况,现在请你编写一个程序,找出一条出发地到目的地之间的最短路径,如果有 ...

  5. QBXT 2018春季DP图论班 2018.4.29 --- 最短路差分约束

    *钟皓曦老师授课* 常见最短路算法: Floyd → O(n^3) //floydint dist[maxn][maxn];memset(dist,0x3f,sizeof(dist)); for (i ...

  6. NOIp 图论算法专题总结 (1):最短路、最小生成树、最近公共祖先

    系列索引: NOIp 图论算法专题总结 (1) NOIp 图论算法专题总结 (2) NOIp 图论算法专题总结 (3) 最短路 Floyd 基本思路:枚举所有点与点的中点,如果从中点走最短,更新两点间 ...

  7. 各种模板(数据结构图论)

    文章目录 数据结构 LCT 线段树 线段树分治 树状数组 图论 Tarjan 静态仙人掌 最小生成树 最短路-Floyd 最短路-Dijkstra 最短路-Bellman-Ford 最短路-SPFA ...

  8. 【算法提高——第三讲(一)】图论

    来自:算法提高课 文章目录 第三章 图论 3.1 单源最短路的建图方式 3.1.1 1129. 热浪 3.1.2 1128. 信使 3.1.3 1127. 香甜的黄油 3.1.4 1126. 最小花费 ...

  9. [存档]xx-09210xxx-2010-ACM-ICPC竞赛总结

    存档作对比.发现完全没进步啊,真惭愧. ==== ACM-ICPC亚洲区预选赛 分区赛竞赛个人总结 2010年赛季 一.个人训练情况 1.训练的数量与质量情况 做题总数: 231=128(BuptOJ ...

  10. NOIP大纲整理:(零)历年2000-2016NOIP提高组题目分析

    年份 题目名称 考查内容 难度   2000-2016年NOIP提高组复赛题目 2000-A 进制转换 初等代数,找规律 ★ 2000-B 乘积最大 资源分配DP ★★★ 2000-C 单词接龙 DF ...

最新文章

  1. return 返回部分值
  2. bzoj2154: Crash的数字表格
  3. OpenCV Mat-基本图像容器
  4. xml配置文件的形式 VS 配置类的形式
  5. htmlcss实例小项目_小程序websocket心跳库——websocket-heartbeat-miniprogram
  6. 携Science封面、NIPS最佳论文,CMU大神博士毕业论文公开
  7. http://blog.51cto.com/forsk/1531568
  8. windows无法访问指定计算机,windows无法访问指定设备路径或文件的解决方法
  9. 【程序设计与实践】实验四:自动寄存柜(C语言)
  10. Global Round 16D2. Seating Arrangements (hard version)(模拟,贪心)
  11. Python+Vue计算机毕业设计酒店管理系统(前台后台)i2agu(源码+程序+LW+部署)
  12. 【tinymce-vue】tinymce-vue自定义图片上传插件,且在插件中调用vue组件
  13. HTML 随机点名 --个人写法
  14. 获取不带后缀名的Excel文件名Python
  15. I帧、P帧、B帧、IDR 关键帧介绍
  16. Mysql的utf8与utf8mb4区别,utf8mb4_bin、utf8mb4_general_ci、utf8mb4_unicode_ci区别
  17. linux下固态硬盘ssd优化
  18. html表单提交和input标签了解
  19. cpu是几核的怎么查看
  20. 非常专业的图形图像处理工具-Adobe Illustrator CS5提供下载

热门文章

  1. 【14】婚礼片剪辑案例【15】电视剧片头剪辑案例
  2. 健康知识竞答线上活动方案——微信答题小程序实现
  3. 天津大学计算机学院王思宇,复杂计算精准化,天津大学选择了宝德HPC
  4. 自动化测试po模式是什么?自动化测试po分层如何实现?-附详细源码
  5. 一小时学会使用SpringBoot整合阿里云SMS短信服务
  6. git commit message——git提交日志规范备忘
  7. Java并发编程(一)——并发的基本概念
  8. linux卸载飞行模式驱动,解决:Ubuntu飞行模式 使用硬件开关关闭
  9. iphone 8 plus 红色特别版,突然自动关机无法启动
  10. 修改内网服务器数据,内网服务器拷数据