全超时了,TLE,求调

P4779 【模板】单源最短路径(标准版)

CCF___NOI @ 2024-07-21 10:31:43

#include<iostream>
#include<iomanip>
using namespace std;
const int N=100007;
const int M=200007;
const int INF=(1<<30)-3;
int st[N],to[N],nx[N],len[M],n,m,s,k;
int tot,stk[10001],top;
void add(int u,int v,int w)
{
    ++tot;
    to[tot]=v;
    len[tot]=w;
    nx[tot]=st[u];
    st[u]=tot;
}
int dis[N];
int vis[N];
int main()
{
    cin>>n>>m>>s;
    for(int i=1;i<=m;i++)
    {
        int a,b,c;
        cin>>a>>b>>c;
        add(a,b,c);
    }
    for(int i=1;i<=n;i++)
        dis[i]=INF;
    dis[s]=0;
    for(int i=1;i<=n;i++)
    {
        int x,d=INF;
        for(int j=1;j<=n;j++)
        {
            if(vis[j]==0&&dis[j]<=d)
            {
                x=j;
                d=dis[j];
            }
        }
        vis[x]=1;
        for(int j=st[x];j!=0;j=nx[j])
        {
            int y=to[j];
            if(dis[x]+len[j]<dis[y])
                dis[y]=dis[x]+len[j];
        }
    }
    for(int i=1;i<=n;i++)
    {
        cout<<dis[i]<<' ';
    }
    return 0;
}

by ny_jerry2 @ 2024-07-21 11:09:27

n \le 10^5$,$m \le 2 \times10^5

用堆优化 dijkstra


|