Mai intai trebuie sa te autentifici.
Cod sursa(job #2580459)
Utilizator | Data | 13 martie 2020 17:26:32 | |
---|---|---|---|
Problema | Floyd-Warshall/Roy-Floyd | Scor | 100 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 1 kb |
#include <bits/stdc++.h>
#define MAX 100
using namespace std;
int mat[MAX + 5][MAX + 5];
int main()
{
ifstream fin("royfloyd.in");
ofstream fout("royfloyd.out");
ios::sync_with_stdio(false);
fin.tie(0);
fout.tie(0);
srand(time(NULL));
int n;
fin >> n;
for(int i = 1; i <= n; i++)
for(int j = 1; j <= n; j++)
fin >> mat[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)continue;
if(mat[i][k] && mat[k][j])
{
if(!mat[i][j])mat[i][j] = mat[i][k] + mat[k][j];
else mat[i][j] = min(mat[i][j], mat[i][k] + mat[k][j]);
}
}
for(int i = 1; i <= n; i++)
{
for(int j = 1; j <= n; j++)
fout << mat[i][j] << " ";
fout << '\n';
}
fin.close();
fout.close();
return 0;
}