百口莫辩克斯 2022-04-14 11:17 采纳率: 61.5%
浏览 31
已结题

洛谷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 11:31
    关注

    超时了,换个算法

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

报告相同问题?

问题事件

  • 系统已结题 4月22日
  • 已采纳回答 4月14日
  • 创建了问题 4月14日

悬赏问题

  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)