Pagini recente » Cod sursa (job #2975471) | Cod sursa (job #1856877) | Cod sursa (job #2975443) | Cod sursa (job #2990227) | Cod sursa (job #2155519)
#include <fstream>
using namespace std ;
#define NMax 105
int A[NMax][NMax] ;
int N ;
void read() {
ifstream f("dijkstra.in") ;
f >> N ;
for(int i = 1 ; i <= N ; i++) {
for(int j = 1 ; j <= N ; j++) {
f >> A[i][j] ;
}
}
f.close() ;
}
void solve() {
for(int k = 1 ; k <= N ; k++) {
for(int i = 1 ; i <= N ; i++) {
for(int j = 1 ; j <= N ; j++) {
if(A[i][k] and A[k][j] and i != j and (A[i][j] > A[i][k] + A[k][j] or !A[i][j])) {
A[i][j] = A[i][k] + A[k][j] ;
}
}
}
}
}
void write() {
ofstream g("dijkstra.out") ;
for(int i = 1 ; i <= N ; i++) {
for(int j = 1 ; j <= N ; j++) {
g << A[i][j] << ' ' ;
}
g << '\n' ;
}
g.close() ;
}
int main() {
read() ;
solve() ;
write() ;
return 0 ;
}