oj加题的时候看能不能过
1 #include<iostream> 2 #include<string.h> 3 #include<stdio.h> 4 #include<queue> 5 using namespace std; 6 7 const int maxn=1005; 8 const int INF=0xffffff; 9 10 int G[maxn][maxn],a[maxn]; 11 int ma[maxn]; 12 13 queue<int>q; 14 int vis[maxn]; 15 int n; 16 17 int bfs(int x) 18 { 19 for(int i=1;i<=n;i++) 20 { 21 a[i]=INF; 22 } 23 while(!q.empty()) 24 q.pop(); 25 memset(vis,0,sizeof(vis)); 26 vis[x]=1; 27 a[x]=0; 28 q.push(x); 29 30 while(!q.empty()) 31 { 32 int tmp=q.front(); 33 q.pop(); 34 for(int i=1;i<=n;i++) 35 { 36 if(G[tmp][i]) 37 { 38 if(a[tmp]+G[tmp][i]<a[i]){ 39 a[i]=a[tmp]+G[tmp][i]; 40 q.push(i); 41 } 42 } 43 } 44 } 45 } 46 47 int bfs2(int x) 48 { 49 for(int i=1;i<=n;i++) 50 { 51 ma[i]=INF; 52 } 53 while(!q.empty()) 54 q.pop(); 55 memset(vis,0,sizeof(vis)); 56 vis[x]=1; 57 ma[x]=0; 58 q.push(x); 59 60 while(!q.empty()) 61 { 62 int tmp=q.front(); 63 q.pop(); 64 for(int i=1;i<=n;i++) 65 { 66 if(G[i][tmp]) 67 { 68 if(ma[tmp]+G[i][tmp]<ma[i]){ 69 ma[i]=ma[tmp]+G[i][tmp]; 70 q.push(i); 71 } 72 } 73 } 74 } 75 } 76 77 78 int main() 79 { 80 int m,x,aa,bb,t; 81 82 while(cin>>n>>m>>x) 83 { 84 memset(G,0,sizeof(G)); 85 86 while(m--) 87 { 88 cin>>aa>>bb>>t; 89 G[aa][bb]=t; 90 } 91 92 93 int sum=0; 94 for(int i=1;i<=n;i++) 95 { 96 bfs(i); 97 bfs2(i); 98 cout<<a[x]<<" "<<ma[x]<<endl; 99 if(sum<a[x]+ma[x]) 100 sum=a[x]+ma[x]; 101 } 102 cout<<sum<<endl; 103 } 104 return 0; 105 }