FOJ 1561 Come Home, Baby!

dijkstra 的表形式
节点大的时候使用
  1. #include <iostream>
  2. using namespace std;
  3. #define N 1000
  4. #define inf 100000000
  5. struct Eage
  6. {
  7.     int a,b,len;
  8. }e[4*N];
  9. int d[N],pre[N],n,t;bool v[N];
  10. void dijkstra()
  11. {
  12.     int i,j,k;
  13.     for(i=0;i<n;i++)d[i]=inf,pre[i]=-1,v[i]=false;d[0]=0;
  14.     for(i=0;i<n;i++)
  15.     {
  16.         for(j=0,k=-1;j<t;j++)//先找出目前距离最小的.贪心
  17.         {
  18.             if(!v[e[j].a]&&(k==-1||d[e[j].a]<d[k]))k=e[j].a;
  19.             if(!v[e[j].b]&&(k==-1||d[e[j].b]<d[k]))k=e[j].b;
  20.         }
  21.         for(v[k]=true,j=0;j<t;j++)//开始,对于未访问的点才pre
  22.         {
  23.             if(k==e[j].a&&!v[e[j].b]&&d[e[j].a]+e[j].len<d[e[j].b])d[e[j].b]=d[e[j].a]+e[j].len,pre[e[j].b]=k;
  24.             if(k==e[j].b&&!v[e[j].a]&&d[e[j].b]+e[j].len<d[e[j].a])d[e[j].a]=d[e[j].b]+e[j].len,pre[e[j].a]=k;
  25.         }
  26.     }
  27. }
  28. int main()
  29. {
  30.     int i,x,y,len;
  31.     while(scanf("%d%d",&t,&n)!=EOF)
  32.     {
  33.        t<<=1;
  34.         for(i=0;i<t;i+=2)
  35.         {
  36.             scanf("%d%d%d",&x,&y,&len);x--;y--;
  37.             e[i].a=x;e[i].b=y;e[i].len=len;
  38.             e[i+1].a=y;e[i+1].b=x;e[i+1].len=len;
  39.         }
  40.         dijkstra();
  41.         printf("%d/n",d[n-1]);
  42.     }
  43.     return 0;
  44. }

你可能感兴趣的:(FOJ 1561 Come Home, Baby!)