测试结果1: 通过本测试点|有效耗时46ms
测试结果2: 通过本测试点|有效耗时47ms
测试结果3: 通过本测试点|有效耗时47ms
测试结果4: 测试结果错误.错误结果为:21100
escape
正确结果应为:4486
escape
测试结果5: 测试结果错误.错误结果为:21100
escape
正确结果应为:160132265414
escape
提交代码:
#include"stdio.h"
#define maxint 2100000000
long g[300][300]={0},G[300][300]={0};
long n,m,t,sum=0;
long min(long a,long b)
{
if(a<b)return a;
return b;
}
int main()
{
scanf("%ld%ld%ld",&n,&m,&t);
for(long i=1;i<=n;i++)
for(long j=1;j<=n;j++)
g[i][j]=maxint;
for(long i=1;i<=m;i++)
{
long a,b,v;
scanf("%ld%ld%ld",&a,&b,&v);
g[a][b]=v;
g[b][a]=v;
}
for(long k=1;k<=n;k++)
for(long i=1;i<=n;i++)
for(long j=1;j<=n;j++)
if(i!=j&&i!=k&&j!=k&&g[i][k]!=maxint&&g[k][j]!=maxint)
g[i][j]=min(g[i][j],g[i][k]+g[k][j]);
for(long i=2;i<=m;i++)
{
if(g[1][i]!=maxint)
sum+=g[1][i]*2;
}
printf("%ld\n",sum);
if(sum>t) printf("escape");
else printf("run");
getchar(),getchar();
return 0;
}
/*
6 7
1 3 4
2 6 1
1 2 4
1 4 8
5 1 1
6 1 6
2 4 2
*/