Cod sursa(job #3325356)

Utilizator CVCiprianConstandache Vlad-Ciprian CVCiprian Data 25 noiembrie 2025 12:55:58
Problema Floyd-Warshall/Roy-Floyd Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.97 kb
#include <bits/stdc++.h>
using namespace std;

int n, a[105][105];

ifstream fin("royfloyd.in");
ofstream fout("royfloyd.out");

int n, m;
void citire(){
	int i, j;
	cin >> n;
	for (i = 1; i <= n; i++)
		for (j = 1; j <= n; j++) 
            cin >> a[i][j];
}

void royfloyd(){
    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;

                int aik = a[i][k], akj = a[k][j];
                
                if (aik == 0 || akj == 0) 
                    continue;
                int cand = aik + akj;
                if (a[i][j] == 0 || a[i][j] > cand) 
                    a[i][j] = cand;
            }
}

void afisare(){
	int i, j;
	for (i = 1; i <= n; i++) 
	{
		for (j = 1; j <= n; j++) 
            cout << a[i][j] << " ";
		cout << "\n";
	}
}

int main()
{
    citire();
	royfloyd();
	afisare();

    return 0;
}