3664 - Cif Par Cif Imp: Difference between revisions

From Bitnami MediaWiki
Dragos1234 (talk | contribs)
 
(3 intermediate revisions by 2 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 de intrare corespund restrictiilor impuse", 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 de intrare nu corespund restrictiilor impuse.
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 ==
== 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 21: 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 27: Line 28:
: Introduceți numărul de numere: 0
: Introduceți numărul de numere: 0
; Iesire
; Iesire
: Numărul de numere trebuie să fie între 1 și 10.
: Datele de intrare nu corespund cerintelor.


== Rezolvare ==
== Rezolvare ==

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>

  1. 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.