fbpx

Problema #466 – GenGraf – Rezolvari PBInfo

de Mihai-Alexandru

Cerinţa

Se dă un număr natural n. Construiți toate grafurile neorientate cu n vârfuri.

Date de intrare

Fişierul de intrare gengraf.in conţine pe prima linie numărul n.

Date de ieşire

Fişierul de ieşire gengraf.out va conţine pe prima linie numărul de grafuri generate M; urmează M matrice de adiacență ale acestor grafuri.

Fiecare matrice va fi afișată astfel: câte o linie a matricei pe o linie a fișierului, elementele de pe o linie fiind separate prin exact un spațiu. După fiecare matrice afișată se va găsi în fișier o linie goală.

Restricţii şi precizări

  • 2 ≤ n ≤ 6
  • cele M matrice de adiacență construite pot fi afișate în orice ordine

Exemplu

gengraf.in

3

gengraf.out

8
0 0 0 
0 0 0 
0 0 0 

0 0 0 
0 0 1 
0 1 0 

0 0 1 
0 0 0 
1 0 0 

0 0 1 
0 0 1 
1 1 0 

0 1 0 
1 0 0 
0 0 0 

0 1 0 
1 0 1 
0 1 0 

0 1 1 
1 0 0 
1 0 0 

0 1 1 
1 0 1 
1 1 0 
#include <bits/stdc++.h>
using namespace std;

ifstream cin("gengraf.in");
ofstream cout("gengraf.out");

int n , m , a[11][11] , x[101] , p;

void afisare()
{
    int k = 1;
    for(int i = 1 ; i <= n ; i++)
        for(int j = i + 1 ; j <= n ; j++)
        {
            a[i][j] = a[j][i] = x[k];
            k++;
        }

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

void back(int k)
{
    for(int i = 0 ; i <= 1 ; i++)
    {
        x[k] = i;
        if(k == m) afisare();
        else back(k + 1);
    }
}

int main()
{
    cin >> n;
    m = n * (n - 1) / 2;
    p = 1 << m;
    cout << p << '\n';
    back(1);
    return 0;
}
Comentarii

S-ar putea sa iti placa