Mai intai trebuie sa te autentifici.
Cod sursa(job #1525747)
| Utilizator | Data | 15 noiembrie 2015 15:23:45 | |
|---|---|---|---|
| Problema | Floyd-Warshall/Roy-Floyd | Scor | 50 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.6 kb |
#include <cstdio>
#include <vector>
#include <algorithm>
using namespace std;
const int MAX = 101;
int n;
int dp[MAX][MAX];
int main() {
freopen("royfloyd.in", "r", stdin);
freopen("royfloyd.out", "w", stdout);
scanf("%d", &n);
for (int i = 1; i <= n; i++)
for (int j = 1; j <= n; j++)
scanf("%d", &dp[i][j]);
for (int k = 1; k <= n; k++)
for (int i = 1; i <= n; i++)
for (int j = 1; j <= n; j++)
if (i != j)
dp[i][j] = min(dp[i][j], dp[i][k] + dp[k][j]);
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= n; j++)
printf("%d ", dp[i][j]);
printf("\n");
}
return 0;
}