比赛 板子大赛 评测结果 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;
}