[HDOJ1874]畅通工程续
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1874
练习,FLOYD和DIJKSTRA解法。有重边
1 #pragma warning(disable:4996) 2 3 4 #include <algorithm> 5 #include <iostream> 6 #include <iomanip> 7 #include <cstring> 8 #include <climits> 9 #include <complex> 10 #include <fstream> 11 #include <cassert> 12 #include <cstdio> 13 #include <bitset> 14 #include <vector> 15 #include <deque> 16 #include <queue> 17 #include <stack> 18 #include <ctime> 19 #include <set> 20 #include <map> 21 #include <cmath> 22 23 using namespace std; 24 25 const int maxn = 2010; 26 const int inf = 0xffffff; 27 int d[maxn]; 28 int G[maxn][maxn]; 29 int vis[maxn]; 30 int n, m; 31 32 void init() { 33 memset(vis, 0, sizeof(vis)); 34 for(int i = 0; i <= n; i++) { 35 d[i] = inf; 36 for(int j = 0; j <= n; j++) { 37 G[i][j] = G[j][i] = inf; 38 } 39 G[i][i] = 0; 40 } 41 } 42 43 void dijkstra(int start) { 44 d[start] = 0; 45 for(int i = 0; i < n; i++) { 46 int u = -1; 47 for(int j = 0; j < n; j++) { 48 if(!vis[j]) { 49 if(u == -1 || d[j] < d[u]) { 50 u = j; 51 } 52 } 53 } 54 vis[u] = 1; 55 for(int j = 0; j < n; j++) { 56 if(!vis[j]) { 57 d[j] = min(d[u]+G[u][j], d[j]); 58 } 59 } 60 } 61 } 62 63 void floyd() { 64 for(int k = 0; k < n; k++) { 65 for(int i = 0; i < n; i++) { 66 for(int j = 0; j < n; j++) { 67 G[i][j] = min(G[i][j], G[i][k]+G[k][j]); 68 } 69 } 70 } 71 } 72 73 int main() { 74 // freopen("in", "r", stdin); 75 int u, v, w; 76 while(~scanf("%d %d", &n, &m)) { 77 init(); 78 while(m--) { 79 scanf("%d %d %d", &u, &v, &w); 80 if(G[u][v] > w) { 81 G[u][v] = G[v][u] = w; 82 } 83 } 84 int S, E; 85 scanf("%d %d", &S, &E); 86 87 /* dijkstra 88 dijkstra(S); 89 printf("%d\n", d[E] == inf ? -1 : d[E]); 90 //*/ 91 92 //* floyd 93 floyd(); 94 printf("%d\n", G[S][E] == inf ? -1 : G[S][E]); 95 //*/ 96 } 97 }
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core GC计划阶段(plan_phase)底层原理浅谈
· .NET开发智能桌面机器人:用.NET IoT库编写驱动控制两个屏幕
· 用纯.NET开发并制作一个智能桌面机器人:从.NET IoT入门开始
· 一个超经典 WinForm,WPF 卡死问题的终极反思
· ASP.NET Core - 日志记录系统(二)
· 支付宝事故这事儿,凭什么又是程序员背锅?有没有可能是这样的...
· 在线客服系统 QPS 突破 240/秒,连接数突破 4000,日请求数接近1000万次,.NET 多
· C# 开发工具Visual Studio 介绍
· 在 Windows 10 上实现免密码 SSH 登录
· C#中如何使用异步编程