1482 - Numar 4

De la Universitas MediaWiki

Enunt

Ionel i-a dat numărul său de telefon N lui Vasile, dar a greșit exact o cifră de pe o anumită poziție. Se cunoaște că pe acea poziție cifra corectă este o cifra pară.

Cerința

Determinați numărul minim NR de numere de telefon pe care trebuie să le încerce Vasile astfel încât printre ele să se afle cu siguranță numărul corect de telefon al lui Ionel.

Date de intrare

Fișierul de intrare numar4.in conține pe prima linie numărul N greșit de telefon transmis de Ionel.

Date de ieșire

Fișierul de ieșire numar4.out va conține pe prima linie numărul NR de combinații necesare lui Vasile pentru a nimeri cu siguranță și numărul corect al lui Ionel.

Restricții și precizări

Numărul N nu poate începe cu cifra 0. Numărul corect poate incepe cu cifra 0. Numărul N are cel mult 9 cifre.

Exemplul 1

numar4.in

72361 numar4.out

23

Explicație

In numarul corect:

Pe prima poziție poate fi una din cifrele: 0, 2, 4, 6, 8 sau Pe a doua poziție poate fi una din cifrele: 0, 4, 6, 8 sau Pe a treia poziție poate fi una din cifrele: 0, 2, 4, 6, 8 sau Pe a patra poziție poate fi una din cifrele: 0, 2, 4, 8 sau Pe a cincea poziție poate fi una din cifrele: 0, 2, 4, 6, 8. Așadar numărul total de combinații posibile este 5+4+5+4+5=23.

Exemplul 2

numar4.in

27544 numar4.out

22

Încărcare soluție

with open("numar4.in") as f_in:
    N = f_in.readline().strip()

valid_digit_count = 0
for i, digit in enumerate(N):
    if int(digit) % 2 == 0:
        valid_digit_count += 1

total_possibilities = 1
for i in range(valid_digit_count):
    total_possibilities *= 5

with open("numar4.out", "w") as f_out:
    f_out.write(str(total_possibilities))