大意是有一条消息要从第一个处理器发送到其余各个处理器,求最长所需的时间。
比较基础的最短路问题,spfa一次过。不过这道题目数据给出的方式比较奇特,它给出的是一个下三角矩阵,且没有给出主对角线上的数据。由题意知把对角线上的数据记为0,然后矩阵关于主对角线对称一下。数据中有字符x,表示无法连通。这种情况下用scanf("%s",ch)+atoi(ch)的方式可以解决。
代码:
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <queue>
#include <iostream>
using namespace std;
const int inf=0x3f3f3f3f;
int n;
int mm[105][105]={0};
int dis[105]={0};
bool had[105]={0};
queue <int> q;
void spfa(){
memset(dis,0x3f,sizeof(dis));
memset(had,0,sizeof(had));
dis[0]=0;q.push(0);
while(!q.empty()){
int t=q.front(); q.pop();
had[t]=0;
for(int i=0;i<n;i++){
if(mm[t][i]!=inf && dis[i]>dis[t]+mm[t][i]){
dis[i]=dis[t]+mm[t][i];
if(!had[i]){
had[i]=1;
q.push(i);
}
}
}
}
}
int main(){
cin>>n;
for(int i=1;i<n;i++){
for(int j=0;j<i;j++){
char ch[20];
scanf("%s",ch);
if(ch[0]=='x') mm[i][j]=mm[j][i]=inf;
else mm[i][j]=mm[j][i]=atoi(ch);
}
}
spfa();
int ans=0;
for(int i=0;i<n;i++){
if(dis[i]>ans) ans=dis[i];
}
cout<<ans<<endl;
return 0;
}