Cerinţa
Se dă lista muchiilor unui graf neorientat. Să se afișeze matricea de adiacență a grafului.
Date de intrare
Fişierul de intrare adiacenta.in
conţine pe prima linie numerele n
și m
, reprezentând numărul de vârfuri ale grafului și numărul de muchii date în continuare. Fiecare dintre următoarele m
linii conține câte o pereche de numere i j
, cu semnificația că există muchie între i
și j
.
Date de ieşire
Fişierul de ieşire adiacenta.out
va conţine n
linii, pe fiecare linie fiind câte n
valori separate prin exact un spațiu, reprezentând matricea de adiacență a grafului dat.
Restricţii şi precizări
1 ≤ n ≤ 100
1 ≤ i , j ≤ n
- muchiile se pot repeta în fișierul de intrare
Exemplu
adiacenta.in
5 8 1 4 1 3 3 5 4 5 2 4 1 2 4 2 3 4
adiacenta.out
0 1 1 1 0 1 0 0 1 0 1 0 0 1 1 1 1 1 0 1 0 0 1 1 0
#include <bits/stdc++.h> using namespace std; ifstream cin("adiacenta.in"); ofstream cout("adiacenta.out"); int n , m , a[101][101] , p , r; int main() { cin >> n >> m; for(int k = 1 ; k <= m ; ++k) { cin >> p >> r; for(int i = 1 ; i <= n ; ++i) { for(int j = 1 ; j <= n ; ++j) { if(i == p && j == r) { a[i][j] = 1; a[j][i] = 1; } } } } for(int i = 1 ; i <= n ; ++i) { for(int j = 1 ; j <= n ; ++j) cout << a[i][j] << " "; cout << endl; } return 0; }