0279 - Distincte

De la Universitas MediaWiki

Cerința

Se dă un şir cu n elemente, numere naturale cu cel mult 8 cifre, ordonate crescător. Afişaţi în ordine crescătoare elementele distincte din şir.

Date de intrare

Fişierul de intrare distincte.in conţine pe prima linie numărul n; urmează cele n elemente ale şirului, dispuse pe mai multe linii şi separate prin spaţii.

Date de ieșire

Pe ecran se va afișa mesajul: "Datele de intrare corespund restricțiilor impuse."

Pe următoarea linie se vor afișa elementele distincte din şir, în ordine crescătoare, fiecare pe o linie.

În cazul în care datele introduse de la tastatură nu îndeplinesc cerințele enunțate, pe ecran se va afișa mesajul "Datele de intrare nu corespund restricțiilor impuse."

Restricții și precizări

  • 1 ≤ n ≤ 10.000

Exemplu 1

Intrare
7
111 111 111 2111 4111 71111 71111
Ieșire
Datele de intrare corespund restricțiilor impuse.
111 2111 4111 71111

Exemplu 3

Intrare
-5
111 111 111 2111 4111 71111 71111
Ieșire
Datele de intrare nu corespund restricțiilor impuse.

Rezolvare

#0279 - Distincte
def conditii(n, numere):
    return len(numere) == n and \
        1 <= n <= 10_000 and \
        numere == sorted(numere) and \
        all(len(str(nr)) <= 8 for nr in numere)


def distincte(numere):
    # set() este o funcție built-in care elimină duplicatele dintr-o listă
    # Folosim sorted() deoarece set() nu returnează un obiect sortat
    print(" ".join(str(x) for x in sorted(set(numere))))


if __name__ == "__main__":
    n = int(input())
    numere = [int(x) for x in input().split()]

    while len(numere) < n:
        numere.extend([int(x) for x in input().split()])

    if not conditii(n, numere):
        print("Datele de intrare nu corespund restricțiilor impuse.")
    else:
        print("Datele de intrare corespund restricțiilor impuse.")
        distincte(numere)