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

poj 2607 Fire Station

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

poj 2607 Fire Station

#include<iostream>#include<cstdio>#include<cstring>#include<cmath>#include<algorithm>#include<string>#include<vector>#include<iostream>#include<queue>#include<stack>#include<cstdlib>#define INF 0x3f3f3f3f#define NODENUM 505#define EDGENUM 501*501using namespace std;int Edge[NODENUM][NODENUM];int dist[NODENUM];int N,M,F;int f[NODENUM];int v[NODENUM];void init(){for(int i=1;i<=N;++i)for(int j=1;j<=N;++j) Edge[i][j]=i==j? 0:INF;memset(v,0,sizeof(v));for(int i=1;i<=N;++i) dist[i]=INF;}void read_case(){init();for(int i=1;i<=F;++i) {scanf("%d",&f[i]);v[f[i]]=1;} getchar();int a,b,len;while(1){char tmp[100];char c=getchar();if(c=='n' || c==-1) break;scanf("%[^n]",tmp+1); getchar();tmp[0]=c; sscanf(tmp,"%d %d %d",&a,&b,&len);Edge[a][b]=Edge[b][a]=len;}}void Floyd(){for(int k=1;k<=N;++k)for(int i=1;i<=N;++i)for(int j=1;j<=N;++j) Edge[i][j]=min(Edge[i][j],Edge[i][k]+Edge[k][j]);}void solve(){for(int i=1;i<=F;++i)for(int j=1;j<=N;++j) dist[j]=min(dist[j],Edge[f[i]][j]);int mindist=INF;int ans=1;for(int k=1;k<=N;++k)if(!v[k]){int maxdist=-INF;for(int i=1;i<=N;++i) maxdist=max(maxdist,min(Edge[k][i],dist[i]));if(maxdist<mindist) mindist=maxdist,ans=k;}printf("%dn",ans);}int main(){while(~scanf("%d %d",&F,&N)){read_case();Floyd();solve();}return 0;}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/375228.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

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

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