| 比赛 | 
    板子大赛 | 
    评测结果 | 
    AAAWWW | 
    | 题目名称 | 
    单源最短路 | 
    最终得分 | 
    50 | 
    | 用户昵称 | 
    IMZ | 
    运行时间 | 
    0.022 s  | 
    | 代码语言 | 
    C++ | 
    内存使用 | 
    3.49 MiB  | 
    | 提交时间 | 
    2025-01-22 14:12:13 | 
显示代码纯文本
#include<bits/stdc++.h>//再思考一下 
using namespace std;
int dis[110][110];
int main(){
    freopen("path.in","r",stdin);
    freopen("path.out","w",stdout);
    int n,m,s;
    scanf("%d%d%d",&n,&m,&s);
    int M=1e9;
    for(int i=1;i<=n;i++){
        for(int j=1;j<=n;j++){
            dis[i][j]=M;
        }
    }
    for(int i=1;i<=m;i++){
        int x,y,w;
        scanf("%d%d%d",&x,&y,&w);
        if(w<dis[x][y]){
            dis[x][y]=w;
            dis[y][x]=w;
        }
    }
    for(int i=1;i<=n;i++){
        for(int j=1;j<=n;j++){
            for(int k=1;k<=n;k++){
                dis[i][j]=min(dis[i][j],dis[i][k]+dis[k][j]);
            }
        }
    }
    for(int i=1;i<=n;i++){
        if(i==s){
            printf("0 ");
        }
        else{
            printf("%d ",dis[s][i]);
        }
    }
    return 0;
}