3664 - Cif Par Cif Imp
Sursă: [1]
Cerinţa[edit | edit source]
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[edit | edit source]
Programul citește de la tastatură numărul n, iar apoi n numere naturale, separate prin spații.
Date de ieşire[edit | edit source]
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[edit | edit source]
- 1 ⩽ n ⩽ 10
- cele n numere citite vor fi mai mici decât 1.000.000.000.
Exemplul 1[edit | edit source]
- 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[edit | edit source]
- Intrare
- Introduceți numărul de numere: 0
- Iesire
- Datele de intrare nu corespund cerintelor.
Rezolvare[edit | edit source]
<syntaxhighlight lang="python" line>
- 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}")
</syntaxhighlight>
Explicatie rezolvare[edit | edit source]
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.