3664 - Cif Par Cif Imp

De la Universitas MediaWiki

Sursă: [1]

Cerinţa

Se dau n numere naturale. Determinaţi câte cifre pare şi câte cifre impare se află în total în cele n numere.

Date de intrare

Programul citește de la tastatură numărul n, iar apoi n numere naturale, separate prin spații.

Date de ieşire

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele introduse corespund cerintelor.", apoi pe un rând nou va afișa numărul de cifre pare și impare separate printr-un spațiu. În caz contrar, se va afișa mesajul:" Datele introduse nu corespund cerintelor."

Restricții și precizări

  • 1 ⩽ n ⩽ 10
  • cele n numere citite vor fi mai mici decât 1.000.000.000.

Exemplul 1

Intrare
Introduceți numărul de numere: 3
Introduceți numărul 1: 11
Introduceți numărul 2: 30
Introduceți numărul 3: 3
Ieșire
Datele de intrare corespund cerintelor.
1 4

Exemplul 2

Intrare
Introduceți numărul de numere: 0
Iesire
Datele de intrare nu corespund cerintelor.

Rezolvare

#3664
def validate_input(n):
    if not 1 <= n <= 10:
        print("Datele introduse nu corespund cerintelor.")
        return False
    return True


def count_parity_digits(n):
    pare = 0
    impare = 0
    while n > 0:
        cifra = n % 10
        if cifra % 2 == 0:
            pare += 1
        else:
            impare += 1
        n //= 10
    return pare, impare


if __name__ == '__main__':
    numere = int(input("Introduceți numărul de numere: "))
    if not validate_input(numere):
        exit()
    pare_total = 0
    impare_total = 0
    for i in range(numere):
        n = int(input(f"Introduceți numărul {i + 1}: "))
        if n >= 1000000000:
            print("Datele de intrare nu corespund cerintelor")
            continue
        pare, impare = count_parity_digits(n)
        pare_total += pare
        impare_total += impare

    print(f"Datele de intrare corespund cerintelor\n{pare_total} {impare_total}")

Explicatie rezolvare

Acest program este o soluție la o problemă care prelucrează un număr dat de numere și calculează numărul total de cifre pare și impare în toate numerele introduse.

Mai întâi, programul folosește funcția `validate_input(n)` pentru a verifica dacă numărul de numere introduse este între 1 și 10. Dacă nu, se afișează un mesaj de eroare și se returnează valoarea `False`.

Apoi, funcția `count_parity_digits(n)` primește un număr `n` și numără cifrele pare și impare în acel număr, utilizând o buclă `while` și operatorul modulo `%`. Rezultatul este returnat sub formă de tuplu.

În blocul principal, utilizatorul este întâi întrebat să introducă numărul de numere pe care le va introduce. Dacă numărul nu este validat cu ajutorul funcției `validate_input()`, programul se încheie. În caz contrar, programul trece printr-o buclă `for` și cere utilizatorului să introducă fiecare număr. Dacă numărul introdus este mai mare sau egal cu 1 miliard, se afișează un mesaj de eroare și se trece la următorul număr. Altfel, se apelează funcția `count_parity_digits()` pentru a număra cifrele pare și impare în numărul introdus și se adaugă la numerele totale de cifre pare și impare.

La sfârșit, programul afișează un mesaj de confirmare și numărul total de cifre pare și impare numărate.