百口莫辩克斯 2022-04-14 03:17 采纳率: 80%
浏览 33
已结题

洛谷P4779最短路径问题TLE

img

#include<bits/stdc++.h>
using namespace std;
int a[10005][10005];
int d[10005],i,j;
const int INF=1e9;
int t;
int read()
{
int x=0,y=1;
char c;
while(c<'0'||c>'9'){if(c=='-')y=-1;c=getchar();}
while(c>='0'&&c<='9'){x=(x<<1)+(x<<3)+(c^48);c=getchar();}
return x*y;
}
void dij(int n)//单源最短路径
{
bool f[10005]={0};
f[1]=1;
int v;
for(i=1;i<n;i++)
{
int min=INF;
for(j=1;j<=n;j++)
{
if(!f[j]&&min>d[j])//找未标记中最小的
{
min=d[j];
v=j;
}
}
f[v]=1;//标记
for(j=v;j<=n;j++)
{
if(!f[j]&&a[v][j]+d[v]<d[j])//更新路径长度
{
d[j]=a[v][j]+d[v];
}
}
}
}

int main()
{
int n,m,x,y,z;
n=read(),m=read(),t=read();
for(i=1;i<=m;i++)
{
x=read(),y=read(),z=read();
a[x][y]=z;
}
for(i=1;i<=n;i++)
{
d[i]=a[t][i];//路径长度初始化]]
}
dij(n);
for(i=1;i<=n;i++)
{
printf("%d\n",d[i]);
}
return 0;
}
爆TLE,请问这个程序哪里出了问题?

展开全部

  • 写回答

1条回答 默认 最新

  • 01010108 2022-04-14 03:31
    关注

    超时了,换个算法

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 4月21日
  • 已采纳回答 4月14日
  • 创建了问题 4月14日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部