0638 – Nivele

From Bitnami MediaWiki

Enunț

Într-un arbore cu rădăcină, spunem că rădăcina este pe nivelul 1, fiii rădăcinii pe nivelul 2, fiii fiilor rădăcinii pe nivelul 3, etc.

Cerința

Se dă vectorul de tați al unui arbore cu rădăcină cu n noduri și k noduri din arbore. Determinați pentru fiecare dintre cele k noduri nivelul pe care se află.

Date de intrare

Fișierul de intrare niveleIN.txt conține pe prima linie numărul de noduri n. Pe linia următoare se află vectorul de tați al arborelui, valorile fiind separate prin spații. Linia a treia conține numărul k, iar linia a patra k noduri, x[1], x[2], … , x[k].

Date de ieșire

Fișierul de ieșire niveleOUT.txt va conține k linii. Linia i va conține nivelul pe care se află nodul x[i] în arborele dat

Restricții și precizări

  • 1 ≤ k ≤ n ≤ 100
  • în vectorul de tați rădăcina este marcată cu 0

Exemplul 1:

niveleIN.txt

7
4 1 7 0 7 7 1 
4
1 3 4 7

niveleOUT.txt

2
4
1
3 

Exemplul 2:

niveleIN.txt

101
4 1 7 0 7 7 1 
4
1 3 4 7

niveleOUT.txt

Datele nu corespund restrictiilor impuse

Rezolvare

<syntaxhighlight lang="python3" line="1"> def verifica_restrictii(n, k, tati):

   if not(1 <= k <= n <= 100) or tati.count(0) != 1:
       with open("niveleOUT.txt", "w") as f_out:
           f_out.write("Datele nu corespund restrictiilor impuse")
       return False
   return True

def determina_nivelul(n, tati, k, noduri):

   # Verificare pentru restricții
   if not verifica_restrictii(n, k, tati):
       return
   nivele = [0] * n  # nivelele pentru fiecare nod
   radacina = tati.index(0) + 1  # găsim poziția rădăcinii în vectorul de tați
   def dfs(nod, nivel):
       nivele[nod - 1] = nivel  # nodurile sunt numerotate de la 1, așa că indexăm cu nod-1
       for fiu in range(1, n + 1):
           if tati[fiu - 1] == nod:
               dfs(fiu, nivel + 1)
   dfs(radacina, 1)
   rezultate = [nivele[nod - 1] for nod in noduri]
   # Scrierea rezultatelor în fișierul de ieșire
   with open("niveleOUT.txt", "w") as f_out:
       for rezultat in rezultate:
           f_out.write(str(rezultat) + "\n")
  1. Citirea datelor de intrare

with open("niveleIN.txt", "r") as f:

   n = int(f.readline().strip())
   tati = list(map(int, f.readline().split()))
   k = int(f.readline().strip())
   noduri = list(map(int, f.readline().split()))
  1. Determinarea nivelului pentru fiecare nod dat

determina_nivelul(n, tati, k, noduri)

</syntaxhighlight>