4156 – Nivele Pare

From Bitnami MediaWiki

Enunț[edit | edit source]

Într-un arbore cu rădăcină, nivelul unui nod este lungimea lanțului de la rădăcină la acel nod. Astfel, rădăcina este pe nivelul 0, fiii rădăcinii pe nivelul 1, fiii fiilor rădăcinii pe nivelul 2, etc.

Cerința[edit | edit source]

Se dă vectorul de tați al unui arbore cu rădăcină cu n noduri. Determinați nodurile situate pe nivele pare.

Date de intrare[edit | edit source]

Fișierul de intrare nivelepareIN.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.

Date de ieșire[edit | edit source]

Fișierul de ieșire nivelepareOUT.txt va conține mai multe linii. Fiecare linie i conține, în ordine crescătoare, nodurile aflate pe nivelul 2*(i-1).În cazul în care restricțiile nu sunt îndeplinite, se va afișa mesajul "Nu corespunde restricțiilor impuse".

Restricții și precizări[edit | edit source]

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

Exemplul 1:[edit | edit source]

nivelepareIN.txt

8
4 3 0 3 2 1 2 1

nivelepareOUT.txt

3
1 5 7

Exemplul 2:[edit | edit source]

nivelepareIN.txt

101
4 3 0 3 2 1 2 1

nivelepareOUT.txt

Datele nu corespund restrictiilor impuse

Rezolvare[edit | edit source]

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

   if 1 <= n <= 100:
       return True
   return False

def citeste_arbore_din_fisier(file_path):

   with open(file_path, 'r') as file:
       n = int(file.readline())
       if not verifica_restrictii(n):
           return None, None, "Datele nu corespund restrictiilor impuse"
       parinti = list(map(int, file.readline().split()))
   return n, parinti, None

def scrie_noduri_pe_nivele_pare(file_path, nivele_pare):

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

def noduri_pe_nivele_pare(n, parinti):

   nivele_pare = [[] for _ in range(n)]
   for i in range(n):
       parinte = parinti[i]
       nivel = 0
       while parinte != 0:
           nivel += 1
           parinte = parinti[parinte - 1]
       if nivel % 2 == 0:
           nivele_pare[nivel // 2].append(i + 1)
   return nivele_pare

if __name__ == "__main__":

   input_file = "nivelepareIN.txt"
   output_file = "nivelepareOUT.txt"
   n, parinti, restrictii_msg = citeste_arbore_din_fisier(input_file)
   if restrictii_msg:
       with open(output_file, 'w') as file:
           file.write(restrictii_msg)
   else:
       nivele_pare = noduri_pe_nivele_pare(n, parinti)
       scrie_noduri_pe_nivele_pare(output_file, nivele_pare)

</syntaxhighlight>