Description
Input
Output
Sample Input
3 2 2 4 3 5 2 1 2 3 6 2 1 2 2 2 5 3 4 4 2 8 5 3 1 5 8 4 1 6 4 10 2 7 5 2 0 2 2 5 1 5 0
Sample Output
3 2 3 10
Source
题目大意是股票经纪人要在一群人中散布一个谣言,而谣言只能在亲密的人中传递,题目各处了人与人之间的关系及传递谣言所用的时间,要求程序给出应以那个人为起点,可以在最短的时间内让所有的人都得知这个谣言。要注意从a到b传递的时间不一定等于从b到a的时间,如果没有方案能够让每一个人都知道谣言,则输出"disjoint"。(有关图的连通性,你懂得!但好像不用考虑这种情况一样能AC,只能说测试数据有点小水!)
题目数据的输入第一行为n,代表总人数,当n=0时结束程序,接着n行,第i+1行的第一个是一个整数t,表示第i个人与t个人的关系要好,接着有t对整数,每对的第一个数是j,表示i与j要好,第二个数是从i直接传递谣言到j所用的时间,数据的输出是两个整数,第一个为选点的散布谣言的起点,第二个整数时所有人得知谣言的最短时间
例如,对于数据1,
可知如果从3开始传播,则1,2得知谣言的时间都是2,所用的时间比从1,2开始传播所用的时间要短,故程序的输出时3 2;(此部分转自http://www.cnblogs.com/ACShiryu/archive/2011/07/28/2119402.html)
Floyd
代码
#include <algorithm> #include <iostream> #include <cstring> #include <cstdio> using namespace std; int mp[101][101]; int t,i,j,n,a,b; void floyd() { for(int i=1;i<=n;++i) { for(int j=1;j<=n;++j) { for(int k=1;k<=n;++k) mp[j][k]=min(mp[j][k],mp[j][i]+mp[i][k]); } } } int main() { while(cin>>n) { if(!n) break; memset(mp,1,sizeof(mp)); for(i=1;i<=n;++i) { cin>>t; while(t--) { cin>>a>>b; mp[i][a]=min(mp[i][a],b); } } floyd(); int maxn,minn=0x7fffffff,v=-1; for(i=1;i<=n;++i) { int max=-1; for(j=1;j<=n;++j) if(max<mp[i][j]&&i!=j) max=mp[i][j]; if(max<minn) { minn=max; v=i; } } if(v==-1) puts("disjoint"); else cout<<v<<" "<<minn<<endl; } return 0; }
poj 1125 Stockbroker Grapevine
原文:http://www.cnblogs.com/ruojisun/p/6361557.html