3303 - Nr Curat

De la Universitas MediaWiki

Sursa: [1]


Cerința

Se dau cel mult 1000 numere naturale mai mici decât 100.000.000. Să se stabilească despre fiecare număr dacă este sau nu curat.

Date de intrare

Fișierul de intrare nrcurat.in conține pe prima linie cel mult 1000 numere naturale mai mici decât 100.000.000, separate prin spații.

Date de ieșire

Fișierul de ieșire nrcurat.out va conține pe prima linie pentru fiecare număr x din fișierul de intrare valoarea 1 dacă x este curat sau 0 în caz contrar. Valorile sunt separate prin câte un spațiu.

Restricții și precizări

în fișier sunt cel mult 1000 de numere naturale mai mici decât 100.000.000

Exemplu

nrcurat.in
345 18 53 986310 467 1638
nrcurat.out
0 1 0 1 0 1

Explicație

Numerele 18, 986310 și 1638 sunt numere curate.

Rezolvare

with open('nrcurat.in', 'r') as f_in, open('nrcurat.out', 'w') as f_out:
    # citim numerele din fisierul de intrare
    numbers = list(map(int, f_in.readline().strip().split()))
    # parcurgem fiecare numar
    for n in numbers:
        clean = True
        # parcurgem fiecare cifra a numarului
        for digit in str(n):
            if digit == '0':
                continue
            if n % int(digit) != 0:
                clean = False
                break
        # scriem rezultatul in fisierul de iesire
        f_out.write('1 ' if clean else '0 ')