讨论 / 怎么wa:60?后面两个点过不去。398
897357142 2011-09-17 02:17:00
点我顶贴 收藏 删除
有效耗时: 140毫秒

测试结果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

*/

#1 lijiaming12340@2011-09-17 02:17:00
回复 删除
n是100000呀!你的floyd能过?
查看更多回复
提交回复