0919 - NrCifreZeroRec1: Difference between revisions

From Bitnami MediaWiki
Cata (talk | contribs)
No edit summary
Cata (talk | contribs)
No edit summary
 
(One intermediate revision by one other user not shown)
Line 7: Line 7:
* Ordinea parametrilor este n , nr
* Ordinea parametrilor este n , nr
* n va fi mai mic decât 2.000.000.000
* n va fi mai mic decât 2.000.000.000
== Explicație ==
Această funcție numără cifrele "0" din numărul dat "n". Funcția primește un număr "n" și un contor "nr" și returnează numărul de cifre "0" din "n".


Funcția verifică dacă "n" este zero și, dacă este cazul, se adaugă 1 la contorul "nr". În caz contrar, funcția verifică dacă ultima cifră a lui "n" este "0" și, dacă este cazul, se adaugă 1 la contorul "nr". Apoi, se face o apelare recursivă a funcției pentru partea "n" fără ultima cifră, până când "n" devine zero. În cele din urmă, funcția returnează numărul total de cifre "0" găsite în "n".
==Date de intrare==
Programul citește de la tastatură numărul n.
 
==Date de ieșire==
Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele introduse sunt corecte.", apoi pe un rând nou un mesaj dat în funcție de valoarea returnată de funcția nr_cif_zero, reprezentând numărul cerut. În cazul în care numărul introdus depășește limitele date, se va afișa "Numarul introdus nu este valid.", iar dacă numărul introdus nu este întreg, se va afișa "Nu ati introdus un numar intreg."
 
==Exemplu==
; Intrare
: Introduceti un numar intreg pozitiv: 1000
; Ieșire
: Datele introduse sunt corecte.
: Numarul de cifre 0 din numarul introdus este: 3


== Rezolvare ==
== Rezolvare ==
Line 16: Line 25:
def validate_n(n):
def validate_n(n):
     if isinstance(n, int) and n >= 0:
     if isinstance(n, int) and n >= 0:
        return True
    else:
        return False
def validate_nr(nr):
    if isinstance(nr, int) and nr >= 0:
         return True
         return True
     else:
     else:
Line 28: Line 31:
def nr_cif_zero(n, nr):
def nr_cif_zero(n, nr):
     if n == 0:
     if n == 0:
         nr += 1
         pass
     elif n > 0:
     elif n > 0:
         if n % 10 == 0:
         if n % 10 == 0:
Line 35: Line 38:
     return nr
     return nr


def main():
if __name__ == "__main__":
     n = input("Introduceti un numar intreg pozitiv: ")
     n = input("Introduceti un numar intreg pozitiv: ")
     try:
     try:
Line 41: Line 44:
         if validate_n(n):
         if validate_n(n):
             nr = nr_cif_zero(n, 0)
             nr = nr_cif_zero(n, 0)
             if validate_nr(nr):
             print("Datele introduse sunt corecte.")
                print(f"Numarul de cifre 0 din numarul introdus este: {nr}")
            print(f"Numarul de cifre 0 din numarul introdus este: {nr}")
            else:
                print("Numarul de cifre 0 obtinut nu este valid.")
         else:
         else:
             print("Numarul introdus nu este valid.")
             print("Numarul introdus nu este valid.")
     except ValueError:
     except ValueError:
         print("Nu ati introdus un numar intreg pozitiv.")
         print("Nu ati introdus un numar intreg.")
</syntaxhighlight>
</syntaxhighlight>
==Explicație==
Funcția `validate_n` primește un parametru `n` și returnează `True` dacă `n` este un număr întreg pozitiv, altfel returnează `False`.
Funcția `nr_cif_zero` primește doi parametri: `n` reprezintă numărul pentru care se caută cifrele 0, iar `nr` este numărul de cifre 0 găsite până în acel moment. Funcția verifică dacă `n` este zero și în acest caz nu face nimic, iar în cazul în care `n` este mai mare decât zero, verifică ultima cifră a lui `n` și, dacă este 0, crește `nr` cu 1. Apoi funcția apelează recursiv `nr_cif_zero` pentru partea lui `n` fără ultima cifră și valoarea `nr` curentizată prin intermediul unui parametru.
În `main`, se citește un număr întreg pozitiv `n` și se verifică dacă acesta este valid. Dacă este valid, se apelează `nr_cif_zero` și se afișează numărul de cifre 0 din numărul introdus. Dacă numărul introdus nu este valid sau nu poate fi convertit la un număr întreg, se afișează un mesaj corespunzător.

Latest revision as of 17:52, 27 April 2023

Cerinţa[edit | edit source]

Să se scrie o funcție Python recursivă care să determine numărul de cifre egale cu zero ale unui număr natural transmis ca parametru și să întoarcă rezultatul prin intermediul unui parametru de ieșire.

Restricţii şi precizări[edit | edit source]

  • Numele funcției va fi nr_cif_zero
  • Funcția va avea doi parametri: n – reprezentând numărul dat și nr – parametrul prin care se întoarce rezultatul
  • Ordinea parametrilor este n , nr
  • n va fi mai mic decât 2.000.000.000

Date de intrare[edit | edit source]

Programul citește de la tastatură numărul n.

Date de ieșire[edit | edit source]

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele introduse sunt corecte.", apoi pe un rând nou un mesaj dat în funcție de valoarea returnată de funcția nr_cif_zero, reprezentând numărul cerut. În cazul în care numărul introdus depășește limitele date, se va afișa "Numarul introdus nu este valid.", iar dacă numărul introdus nu este întreg, se va afișa "Nu ati introdus un numar intreg."

Exemplu[edit | edit source]

Intrare
Introduceti un numar intreg pozitiv: 1000
Ieșire
Datele introduse sunt corecte.
Numarul de cifre 0 din numarul introdus este: 3

Rezolvare[edit | edit source]

<syntaxhighlight lang="python"> def validate_n(n):

   if isinstance(n, int) and n >= 0:
       return True
   else:
       return False

def nr_cif_zero(n, nr):

   if n == 0:
       pass
   elif n > 0:
       if n % 10 == 0:
           nr += 1
       nr = nr_cif_zero(n // 10, nr)
   return nr

if __name__ == "__main__":

   n = input("Introduceti un numar intreg pozitiv: ")
   try:
       n = int(n)
       if validate_n(n):
           nr = nr_cif_zero(n, 0)
           print("Datele introduse sunt corecte.")
           print(f"Numarul de cifre 0 din numarul introdus este: {nr}")
       else:
           print("Numarul introdus nu este valid.")
   except ValueError:
       print("Nu ati introdus un numar intreg.")

</syntaxhighlight>

Explicație[edit | edit source]

Funcția `validate_n` primește un parametru `n` și returnează `True` dacă `n` este un număr întreg pozitiv, altfel returnează `False`.

Funcția `nr_cif_zero` primește doi parametri: `n` reprezintă numărul pentru care se caută cifrele 0, iar `nr` este numărul de cifre 0 găsite până în acel moment. Funcția verifică dacă `n` este zero și în acest caz nu face nimic, iar în cazul în care `n` este mai mare decât zero, verifică ultima cifră a lui `n` și, dacă este 0, crește `nr` cu 1. Apoi funcția apelează recursiv `nr_cif_zero` pentru partea lui `n` fără ultima cifră și valoarea `nr` curentizată prin intermediul unui parametru.

În `main`, se citește un număr întreg pozitiv `n` și se verifică dacă acesta este valid. Dacă este valid, se apelează `nr_cif_zero` și se afișează numărul de cifre 0 din numărul introdus. Dacă numărul introdus nu este valid sau nu poate fi convertit la un număr întreg, se afișează un mesaj corespunzător.