#include<bits/stdc++.h>
using namespace std;
int n, s, dis[55], scan[55], node[55][55], num, cur, inf = 1e5;
int findNext(){
int loc = -1, minDis = -1;
for(int i = 0;i < n; i++){
if(scan[i]) continue;
if(minDis == -1) minDis = dis[i], loc = i;
else {
if(minDis > dis[i]) minDis = dis[i], loc = i;
}
}return loc;
}
int main() {
for(int i = 0; i < 55; i++) dis[i] = inf;
cin >> n >> s;
for(int i = 0; i < n; i++)
for(int j = 0; j < n; j++){
cin >> num;
node[i][j] = num;
}dis[s] = 0;
for(int cnt = 1; cnt < n; cnt++){
if((cur = findNext()) == -1) break;
scan[cur] = 1;
for(int i = 0; i < n; i++){
if(node[cur][i] == 0) continue;
dis[i] = min(dis[i], node[cur][i] + dis[cur]);
}
}
for(int i = 0; i < n; i++){
if(i == s) continue;
if(dis[i] == inf) cout << -1 << ' ';
else cout << dis[i] << ' ';
}cout << "\n";
return 0;
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复