#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分
4 人评分
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:886 |
C语言程序设计教程(第三版)课后习题6.10 (C语言代码)浏览:1055 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:961 |
C二级辅导-阶乘数列 (C语言代码)浏览:689 |
Hello, world! (C++代码)浏览:1744 |
C语言程序设计教程(第三版)课后习题10.1 (C语言代码)浏览:562 |
字符逆序 (C语言代码)浏览:457 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:558 |
局部变量作函数返回值的问题浏览:968 |
C语言程序设计教程(第三版)课后习题11.3 (C语言代码)浏览:566 |