3664 - Cif Par Cif Imp: Difference between revisions
Nagy Lenard (talk | contribs) No edit summary |
|||
(10 intermediate revisions by 3 users not shown) | |||
Line 8: | Line 8: | ||
== Date de ieşire == | == 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." | |||
Datele | |||
== Restricții și precizări == | == Restricții și precizări == | ||
* 1 ⩽ n ⩽ 10 | * 1 ⩽ '''n''' ⩽ 10 | ||
* cele '''n''' numere citite vor fi mai mici decât '''1.000.000.000'''. | * cele '''n''' numere citite vor fi mai mici decât '''1.000.000.000'''. | ||
Line 23: | Line 21: | ||
: Introduceți numărul 3: 3 | : Introduceți numărul 3: 3 | ||
; Ieșire | ; Ieșire | ||
: Datele de intrare corespund cerintelor. | |||
: 1 4 | : 1 4 | ||
Line 29: | Line 28: | ||
: Introduceți numărul de numere: 0 | : Introduceți numărul de numere: 0 | ||
; Iesire | ; Iesire | ||
: | : Datele de intrare nu corespund cerintelor. | ||
== Rezolvare == | == Rezolvare == | ||
Line 37: | Line 36: | ||
def validate_input(n): | def validate_input(n): | ||
if not 1 <= n <= 10: | if not 1 <= n <= 10: | ||
print(" | print("Datele introduse nu corespund cerintelor.") | ||
return False | return False | ||
return True | return True | ||
Line 64: | Line 63: | ||
n = int(input(f"Introduceți numărul {i + 1}: ")) | n = int(input(f"Introduceți numărul {i + 1}: ")) | ||
if n >= 1000000000: | if n >= 1000000000: | ||
print(" | print("Datele de intrare nu corespund cerintelor") | ||
continue | continue | ||
pare, impare = count_parity_digits(n) | pare, impare = count_parity_digits(n) | ||
Line 70: | Line 69: | ||
impare_total += impare | impare_total += impare | ||
print(f"{pare_total} {impare_total}") | print(f"Datele de intrare corespund cerintelor\n{pare_total} {impare_total}") | ||
</syntaxhighlight> | |||
==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. |
Latest revision as of 19:07, 14 May 2023
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.