4072 - Graf Partial 5

From Bitnami MediaWiki

Cerinţa

Se dă lista muchiilor unui graf neorientat cu n vârfuri, etichetate de la 1 la n și un număr natural k. Din acest graf se elimină toate muchiile care au ambele extremități în vârfuri de grad mai mare sau egal cu k. Să se afișeze matricea de adiacență a grafului parțial obținut.

Date de intrare

Fişierul de intrare graf_partial_5IN.txt conţine pe prima linie numărul n, reprezentând numărul de vârfuri ale grafului și numărul k. 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 graf_partial_5OUT.txt va conţine matricea de adiacență a grafului parțial obținut, câte o linie a matricei pe o linie a fișierului, elementele de pe fiecare linie fiind separate prin exact un spațiu.

Restricţii şi precizări

  • 1 < k < n ≤ 100
  • 1 ≤ i , j ≤ n
  • muchiile se pot repeta în fișierul de intrare

Exemplul 1

graf_partial_5IN.txt

6 3
1 4
2 5
2 4
2 1
4 5
3 2
4 3
2 6
3 6

graf_partial_5OUT.txt

0 1 0 1 0 0 
1 0 0 0 1 1 
0 0 0 0 0 1 
1 0 0 0 1 0 
0 1 0 1 0 0 
0 1 1 0 0 0 

Explicație

Se elimină muchiile (2 3), (4 3), (2 4) deoarece vârfurile 2, 3 și 4 au gradul mai mare sau egal cu 3.

Exemplul 2

graf_partial_5IN.txt

1000 1000

graf_partial_5OUT.txt

Datele nu corespund restrictiilor impuse

Rezolvare

<syntaxhighlight lang="python3" line="1"> def citeste_input(cale_fisier):

   with open(cale_fisier, 'r') as fisier:
       n, k = map(int, fisier.readline().split())
       muchii = [tuple(map(int, linie.split())) for linie in fisier]
   return n, k, muchii

def verifica_restrictii(n, k, muchii):

   if not (1 < k < n <= 100):
       return False
   for muchie in muchii:
       if not (1 <= muchie[0] <= n and 1 <= muchie[1] <= n):
           return False
   return True

def construieste_matrice_adiacenta(n, muchii):

   matrice = [[0] * n for _ in range(n)]
   for muchie in muchii:
       matrice[muchie[0] - 1][muchie[1] - 1] = 1
       matrice[muchie[1] - 1][muchie[0] - 1] = 1
   return matrice

def elimina_muchii_grad_inalt(matrice, k):

   grade = [sum(rand) for rand in matrice]
   for i in range(len(matrice)):
       for j in range(len(matrice[i])):
           if grade[i] >= k and grade[j] >= k:
               matrice[i][j] = matrice[j][i] = 0
   return matrice

def scrie_output(cale_fisier, matrice):

   with open(cale_fisier, 'w') as fisier:
       for rand in matrice:
           fisier.write(' '.join(map(str, rand)) + '\n')

if __name__ == "__main__":

   fisier_input = "graf_partial_5IN.txt"
   fisier_output = "graf_partial_5OUT.txt"
   n, k, muchii = citeste_input(fisier_input)
   if not verifica_restrictii(n, k, muchii):
       with open(fisier_output, 'w') as fisier:
           fisier.write("Datele nu corespund restrictiilor impuse")
   else:
       matrice_adiacenta = construieste_matrice_adiacenta(n, muchii)
       matrice_modificata = elimina_muchii_grad_inalt(matrice_adiacenta, k)
       scrie_output(fisier_output, matrice_modificata)

</syntaxhighlight>