fbpx

Problema #412 – Adiacenta – Rezolvari PBInfo

de Mihai-Alexandru

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;
}
Comentarii

S-ar putea sa iti placa