求助 第三个点wa
查看原帖
求助 第三个点wa
97019
wangyaping楼主2021/8/14 15:19
#include<iostream>
#include<cstring>
#include<climits>
using namespace std;
const int N = 1e4 + 10,M = 5e5 + 10;
int n,m,s,idx;
int h[N],e[M],w[M],ne[M],dist[N],vis[N];
void add(int a,int b,int c){
    e[idx] = b;
    w[idx] = c;
    ne[idx] = h[a];
    h[a] = idx++;
    return;
}
void dijkstra(){
    for(int i = 1;i <= n;i++) dist[i] = INT_MAX;
    dist[s] = 0;
    for(int i = 1;i <= n;i++){
        int t = -1;
        for(int j = 1;j <= n;j++){
            if(!vis[j] && (t == -1 || dist[t] > dist[j])) t = j;
        }
        vis[t] = true;
        for(int j = h[t];j != -1;j = ne[j]){
            int k = e[j];
            dist[k] = min(dist[k],dist[t] + w[j]);
        }
    }
    for(int i = 1;i <= n;i++) printf("%d ",dist[i]);
    return;
}
int main(){
    scanf("%d%d%d",&n,&m,&s);
    memset(h,-1,sizeof h);
    for(int i = 0;i < m;i++){
        int u,v,w;
        scanf("%d%d%d",&u,&v,&w);
        add(u,v,w);
    }
    dijkstra();
    return 0;
}
2021/8/14 15:19
加载中...