0475 - Lant

From Bitnami MediaWiki

Cerinţa

Se dă lista muchiilor unui graf neorientat cu n vârfuri și două vârfuri p q. Să se determine toate lanțurile elementare cu extremitățile p și q.

Date de intrare

Fişierul de intrare lantIN.txt 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.

Următoarea linie conține două numere p q.

Date de ieşire

Fişierul de ieşire lantOUT.txt va conține, în ordine lexicografică, toate lanțurile elementare cu extremitățile în p, respectiv q, fiecare lanț fiind afișat pe câte o linie a fișierului, vârfurile dintr-un lanț fiind separate prin exact un spațiu.În cazul în care restricțiile nu sunt îndeplinite, se va afișa mesajul "Nu corespunde restricțiilor impuse".

Restricţii şi precizări

  • 1 ≤ n ≤ 20
  • 1 ≤ i , j ≤n
  • muchiile se pot repeta în fișierul de intrare
  • 1 ≤ p , q ≤ n

Exemplul 1:

lantIN.txt

5 8
1 4 
1 3 
3 5 
4 5 
2 4 
1 2 
4 2 
3 4
2 5

lantOUT.txt

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

Exemplul 2:

lantIN.txt

1000 100
1 4 
1 3 
3 5 
4 5 
2 4 
1 2 
4 2 
3 4
2 5

lantOUT.txt

Datele nu corespund restrictiilor impuse

Rezolvare

<syntaxhighlight lang="python3" line="1"> def verifica_restrictii(n, muchii, p, q):

   if not (1 <= n <= 20):
       return False
   for u, v in muchii:
       if not (1 <= u <= n) or not (1 <= v <= n):
           return False
   if not (1 <= p <= n) or not (1 <= q <= n):
       return False
   return True

def citeste_graf(file_path):

   with open(file_path, 'r') as file:
       n, m = map(int, file.readline().split())
       muchii = [tuple(map(int, file.readline().split())) for _ in range(m)]
       try:
           p, q = map(int, file.readline().split())
       except ValueError:
           with open("lantOUT.txt", 'w') as file_out:
               file_out.write("Datele nu corespund restrictiilor impuse")
           exit()
   if not verifica_restrictii(n, muchii, p, q):
       with open("lantOUT.txt", 'w') as file_out:
           file_out.write("Datele nu corespund restrictiilor impuse")
       exit()
   return n, muchii, p, q

def dfs(v, tinta, graf, vizitat, path, rezultat):

   vizitat[v] = True
   path.append(v)
   if v == tinta:
       rezultat.append(path.copy())
   else:
       for vecin in graf[v]:
           if not vizitat[vecin]:
               dfs(vecin, tinta, graf, vizitat, path, rezultat)
   path.pop()
   vizitat[v] = False

def gaseste_lanturi(n, muchii, p, q):

   graf = {i: [] for i in range(1, n + 1)}
   for u, v in muchii:
       graf[u].append(v)
       graf[v].append(u)
   vizitat = {i: False for i in range(1, n + 1)}
   rezultat = []
   dfs(p, q, graf, vizitat, [], rezultat)
   rezultat = list(set(tuple(lant) for lant in rezultat))
   rezultat.sort()
   return rezultat

def scrie_lanturi(file_path, lanturi):

   with open(file_path, 'w') as file:
       for lant in lanturi:
           file.write(' '.join(map(str, lant)) + '\n')

if __name__ == "__main__":

   file_in = "lantIN.txt"
   file_out = "lantOUT.txt"
   n, muchii, p, q = citeste_graf(file_in)
   rezultat = gaseste_lanturi(n, muchii, p, q)
   scrie_lanturi(file_out, rezultat)

</syntaxhighlight>