栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

poj 3967 Ideal Path

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

poj 3967 Ideal Path

#include <iostream>  #include <stdio.h>  #include <cmath>  #include <algorithm>  #include <iomanip>  #include <cstdlib>  #include <string>  #include <string.h>  #include <vector>  #include <queue>  #include <stack>  #include <map>#include <set>#include <ctype.h>  #define INF 1<<30         #define ll long long         #define max3(a,b,c) max(a,max(b,c))         #define MAXN 1000    using namespace std;    struct edge{        int v;        int c;    };    edge eg[410000];int head[410000];  int next[410000];int level[110000];int tmp[410000];bool vis[110000];    int minc[110000]; int Q[410000];int main(){    int n,m;        while(~scanf("%d%d",&n,&m)){     int front=0;          int rear=0;          memset(level,0,sizeof(level)); memset(head,-1,sizeof(head));          memset(next,-1,sizeof(next));          memset(vis,0,sizeof(vis)); for(int i=0;i<=n;i++)minc[i]=INF;          for(int i=1;i<=m;i++){     int u,v,c;     scanf("%d%d%d",&u,&v,&c);     int h;   eg[i*2-1].v=v; eg[i*2-1].c=c;    next[i*2-1]=head[u];   head[u]=i*2-1;   eg[i*2].v=u; eg[i*2].c=c;     next[i*2]=head[v];   head[v]=i*2;          }          Q[rear++]=n;          level[n]=1; vis[n]=1;          while(front!=rear){       int cur=Q[front]; front++;     int t=head[cur];   while(t!=-1){         int v=eg[t].v;         if( !vis[v]){  level[v]=level[cur]+1;   Q[rear++]=v;vis[v]=1;         }         t=next[t];   } }memset(vis,0,sizeof(vis));         int test=rear;          front=rear=0;          Q[rear++]=1;          int k=level[1];          for(int i=k;i>1;i--){   int end=0;   while(front!=rear){         int cur=Q[front]; front++;       tmp[end++]=cur;   }   for(int j=0;j<end;j++){       int cur=tmp[j];       int t=head[cur];        while(t!=-1){int v=eg[t].v;if( !vis[v]&&level[v]==i-1 && eg[t].c<minc[i-1]  ){      minc[i-1]= eg[t].c;  }  t=next[t];       }   }   for(int j=0;j<end;j++){       int cur=tmp[j];       int t=head[cur];        while(t!=-1){int v=eg[t].v;if( !vis[v]&&level[v]==i-1 && eg[t].c==minc[i-1]  ){      vis[v]=1;  Q[rear++]=v;} t=next[t];       }   }          }          printf("%dn",level[1]-1); for(int i=k-1;i>=1;i--){   printf("%d",minc[i]);   if(i!=1)printf(" ");          }          printf("n");      }        return 0;    }
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/375875.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号