资讯 小学 初中 高中 语言 会计职称 学历提升 法考 计算机考试 医护考试 建工考试 教育百科
栏目分类:
子分类:
返回
空麓网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
空麓网 > 计算机考试 > 面试经验 > 面试问答

poj 3967 Ideal Path

面试问答 更新时间: 发布时间: 计算机考试归档 最新发布

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;    }
转载请注明:文章转载自 http://www.konglu.com/
本文地址:http://www.konglu.com/it/375875.html
免责声明:

我们致力于保护作者版权,注重分享,被刊用文章【poj 3967 Ideal Path】因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理,本文部分文字与图片资源来自于网络,转载此文是出于传递更多信息之目的,若有来源标注错误或侵犯了您的合法权益,请立即通知我们,情况属实,我们会第一时间予以删除,并同时向您表示歉意,谢谢!

我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2023 成都空麓科技有限公司

ICP备案号:蜀ICP备2023000828号-2