模板
void floyd() { int num; cin>>num; for(int i=1;i<=num;i++) { for(int j=1;j<=num;j++) { if(i==j)continue; else z[i][j]=0x3f3f3f3f; } } for(int k=1;k<=num;k++) { for(int i=1;i<=num;i++) { for(int j=1;j<=num;j++) { z[i][j]=min(z[i][j],z[i][k]+z[k][j]); } } } }
例题1
题解
#include<iomanip>//保留小数位数 #include<iostream> //c++ #include<algorithm> //sort排序 #include<cstring> //字符串 #include<math.h> //abs等函数 #include<map> //map #include<set>//set #include<cctype> #define int long long //不开longlong见祖宗 #define endl '\n' //处理多数据时省时间 using namespace std; int z[1110][1110]; int people[1110]; int num; void floyd() { for (int k = 1; k <= num; k++) { for (int i = 1; i <= num; i++) { for (int j = 1; j <= num; j++) { z[i][j] = min(z[i][k] + z[k][j],z[i][j]); } } } } signed main() { ios::sync_with_stdio(false); cin.tie(0); //cin减少时间 cout.tie(0); //cout减少时间 cin >> num; //初始化自己到自己的距离为0 其他的都为无穷大 for (int i = 1; i <= num; i++) { for (int j = 1; j <= num; j++) { if (i == j) z[i][j] = 0; else z[i][j] = 0x3f3f3f3f; } } for (int i = 1; i <= num; i++) { int a, b, c; cin >> a >> b >> c; //记录当前医院的人数为a people[i] = a; if (b) { //双向的权值都赋值为1 z[i][b] = 1; z[b][i] = 1; } if (c) { z[i][c] = 1; z[c][i] = 1; } } //使得两点的距离最小 floyd(); int ans = 0x3f3f3f3f;//先定义答案为无穷大 //外层for循环定义结点 内层for循坏找答案 for (int i = 1; i <= num; i++) { int sum = 0; for (int j = 1; j <= num; j++) { sum = sum + people[j] * z[i][j];//当前结点人数=j结点人数*ij之间的距离 } ans = min(ans, sum);//找到最小值 } cout << ans; return 0; //cout << setw(5) << setfill('0') << a << b;// 输出5位,右对齐,不足补0 。 }