POJ1125
来源:互联网 发布:语音交友软件 编辑:程序博客网 时间:2024/05/17 20:27
题目链接:点击打开链接
不枉我一早起来看最短路径啊,一下子就接受了。这道题就是一道有向图求最短路径。我用的是Dijkstra算法,遍历每一个点为起点。求出每个点到他最远的点的距离。
注意这道题用的是最短路径的方法,其实意思是一个人要把信息传达给大家,但是好像这个人可以同时传达信息给他所能传达到的人。
比如:
1 传给 2和3的时间都是 3分钟的话,那么1传话给大家的时间就是三分钟。但是不同人之间的传递是不同时的,比如1传给2、3要3分钟,2传给4要2分钟。那么1要把话传给大家就需要3 + 2 =5分钟。总之就是选取1要传达到的信息的最远的那个人。然后遍历所有点求谁能最快把消息让大家都知道。
下面是用Dijkstra算法实现的代码:
#include<stdio.h>#include<string.h>int const N = 110;bool mark[N];int n, m;int Dijkstre(int i, int d[][N]){int j, k, t;int min, min_k;for(j = 1; j < n; ++j){min = 999999, min_k = -1;for(k = 1; k <= n; ++k){if(d[i][k] > 0 && mark[k] == 0 && d[i][k] < min)min = d[i][k], min_k = k;}if(min_k == -1)return -1;mark[min_k] = 1;for(t = 1; t <= n; ++t){if(d[min_k][t] > 0){if(mark[t] == 0 && d[i][t] < 0 || d[min_k][t] + min < d[i][t])d[i][t] = d[min_k][t] + min;}}}return min;}int main(){int d[N][N];int i, j, k;int a, b;while(scanf("%d", &n) != EOF && n){/*------------初始化-----------------*/memset(d, -1, sizeof(d));for(i = 1; i <= n; ++i){ scanf("%d", &m);while(m--){scanf("%d%d", &a, &b);d[i][a] = b;}}/*------------------------------------*/int ans1 = 1, ans2 = 999999, tt;for(i = 1; i <= n; ++i){memset(mark, 0, sizeof(mark));mark[i] = 1;tt = Dijkstre(i, d);if(tt > 0 && tt < ans2)ans1 = i, ans2 = tt;}if(ans2 == 999999)printf("disjoint\n");elseprintf("%d %d\n", ans1, ans2);}return 0;}
都说FLoyed的算法写起来比较简单,所以也写了一下,运行的效率都是一样的。
Source CodeProblem: 1125User: BearoxMemory: 176KTime: 0MSLanguage: C++Result: AcceptedSource Code#include<stdio.h>#include<string.h>int const N = 110;int m, n;int main(){int i, j, k;int d[N][N];int a, b;while(scanf("%d", &n) != EOF && n){memset(d, -1, sizeof(d));for(i = 1; i <= n; ++i){ scanf("%d", &m);while(m--){scanf("%d%d", &a, &b);d[i][a] = b;}}for(i = 1; i <= n; ++i)for(j = 1; j <= n; ++j)for(k = 1; k <= n; ++k)if(d[j][i] > 0 && d[i][k] > 0 && (d[j][i] + d[i][k] < d[j][k] || d[j][k] < 0))d[j][k] = d[j][i] + d[i][k];b = 999999;int tj = -1;for(i = 1; i <= n; ++i){a = -1;for(j = 1; j <= n; ++j){if(i == j)continue;if(d[i][j] < 0){a = -1;break;}a = a < d[i][j]? d[i][j] : a;}if(a > 0 && a < b)b = a, tj = i;}if(b == 999999)printf("disjoint\n");elseprintf("%d %d\n", tj, b);}return 0;}
- poj1125
- poj1125
- poj1125
- POJ1125
- poj1125
- POJ1125
- poj1125
- poj1125
- poj1125
- POJ1125
- poj1125
- poj1125
- poj1125(Floyd)
- poj1125 Stockbroker
- POJ1125-Floyd
- poj1125 (Floyd)
- POJ1125 Floyd
- poj1125--Floyd
- 编解码--HEVC,SVC
- HDU 1166 敌兵布阵(线段树)
- 嵌入式Linux系统下I2C设备驱动程序的开发
- 362. Prevention is better than cure. 预防胜于治疗
- 小巫随笔6
- POJ1125
- IT从业者身体素质普遍不好
- 当你浮躁的时候,牢记这些话!看到第五句舒坦了!
- iOS网络编程-ASIHTTPRequest框架同步请求
- 程序员的追求是什么?
- 家长如何检查孩子的作业(转)
- 再谈浮躁
- 三谈浮躁
- cocos2d-x魔塔20层码源和制作心得