4156 – Nivele Pare

De la Universitas MediaWiki

Enunț

Î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

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

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

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

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

Exemplul 1:

nivelepareIN.txt

8
4 3 0 3 2 1 2 1

nivelepareOUT.txt

3
1 5 7

Exemplul 2:

nivelepareIN.txt

101
4 3 0 3 2 1 2 1

nivelepareOUT.txt

Datele nu corespund restrictiilor impuse

Rezolvare

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)