Cerinţa
Se dă lista muchiilor unui graf neorientat cu n
vârfuri, etichetate de la 1
la n
. Din acest graf se elimină toate vârfurile care au gradul minim. Să se determine câte muchii va avea subgraful obținut.
Date de intrare
Fişierul de intrare subgraf1.in
conţine pe prima linie numărul n
, reprezentând numărul de vârfuri ale grafului. Fiecare dintre următoarele 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 subgraf1.out
va conţine pe prima linie numărul M
de muchii ale subgrafului obținut.
Restricţii şi precizări
1 ≤ n ≤ 100
1 ≤ i , j ≤ n
- muchiile se pot repeta în fișierul de intrare
Exemplu
subgraf1.in
5 1 5 2 5 3 5 2 3 4 2
subgraf1.out
3
Explicație
Se elimină vârfurile 1 4
. Subgraful obținut va conține vârfurile 2 3 5
, cu 3
muchii.
#include <bits/stdc++.h> using namespace std; ifstream fin ("subgraf1.in"); ofstream fout ("subgraf1.out"); int a[101][101] , n , p , r , m , mn = 1000000000; int main() { fin >> n; while(fin >> p >> r) { if (a[p][r] == 0) { a[p][0]++; a[r][0]++; m++; } a[p][r] = 1; a[r][p] = 1; } for (int i = 1; i <= n; i++) mn = min(a[i][0], mn); for (int i = 1; i <= n; i++) { if (a[i][0] == mn) for (int j = 1; j <= n; j++) { if (a[i][j] == 1) { a[i][j] = 0; m--; } a[j][i] = 0; } } fout << m; return 0; }