题目电波: POJ--1797 Heavy Transportation 

n点m条边, 求1到n最短边最大的路径的最短边长度 
改进dijikstra,dist[i]数组保存源点到i点的最短边最大的路径的最短边长度

 

#include<iostream>
#include<cstring>
#include<algorithm>
#include<stdio.h>
using namespace std;
#define maxn 100010
#define inf 0x3f3f3f3f
struct ac{
  int x,y;
  ac(){}
  ac(int a,int b){
    x=a,y=b;
  }
}a[maxn];
struct wa{
  int to,va,nex;
}eg[maxn];
int dis[maxn],head[maxn];
bool fa[maxn];
int n,m,tot,len;
void init(){
   memset(head,-1,sizeof(head));
   memset(eg,0,sizeof(eg));
   memset(fa,0,sizeof(fa));
   tot=0,len=0;
}
void add_eg(int u,int v,int va){
   eg[tot].to=v;
   eg[tot].va=va;
   eg[tot].nex=head[u];
   head[u]=tot++;

   eg[tot].to=u;
   eg[tot].va=va;
   eg[tot].nex=head[v];
   head[v]=tot++;
}
bool xxx(ac q,ac w){
  if(q.x>w.x) return 1;
  return 0;
}
void add(int v){
    if(v==1) return ;
    if(xxx(a[v],a[v/2])){
       swap(a[v],a[v/2]);
       add(v/2);
    }
}
void updata(int v){
   if(v*2>len) return ;
   if(v*2==len){
      if(xxx(a[v*2],a[v])) swap(a[v],a[v*2]);
      return ;
   }
   if(xxx(a[v],a[v*2])&&xxx(a[v],a[v*2+1])) return ;
   if(xxx(a[v*2],a[v*2+1])){
      swap(a[v*2],a[v]);
      updata(v*2);
   }else{
      swap(a[v*2+1],a[v]);
      updata(v*2+1);
   }
}
void dijstra(){
   memset(dis,0,sizeof(dis));
   memset(fa,0,sizeof(fa));
   dis[1]=inf;
   a[++len]=ac(inf,1);
   while(len){
      ac x=a[1];
      int u=x.y;
      swap(a[1],a[len--]),updata(1);
      if(fa[u]) continue;
      fa[u]=1;
      for(int j=head[u];j!=-1;j=eg[j].nex){
         int v=eg[j].to;
         int va=eg[j].va;
         if(dis[v]<min(dis[u],va)){
            dis[v]=min(dis[u],va);
            a[++len]=ac(dis[v],v);
            add(len);
         }
      }
   }
}
int main(){
   int t,zz=1;
   cin>>t;
   while(t--){
     cin>>n>>m;
     init();
     for(int j=0;j<m;j++){
        int u,v,va;
         scanf("%d%d%d",&u,&v,&va);
        add_eg(u,v,va);
     }
     dijstra();
     printf("Scenario #%d:\n%d\n\n",zz++,dis[n]);
   }
}