3303 - Nr Curat
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
</syntaxhighlight> 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 ')
</syntaxhighlight>