0919 - NrCifreZeroRec1: Difference between revisions

From Bitnami MediaWiki
Cata (talk | contribs)
No edit summary
Tag: visualeditor
No edit summary
Line 1: Line 1:
== Cerinţa ==
== Cerinţa ==
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.
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.
==Date de intrare==
Se va introduce de la tastatură un număr natural care va fi transmis ca perimetru
==Date de ieșire==
Dacă datele de intrare corespund restrictiilor impuse se va afișa mesajul "Datele de intrare corespund restricțiilor" și pe un rând nou se afișează ceea ce se cere. Altfel, dacă datele de intrare nu corespund cerinței se va afișa mesajul: "Datele de intrare nu corespund cerinței".


== Restricţii şi precizări ==
== Restricţii şi precizări ==
Line 7: Line 13:
* 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 ==
==Exemplu ==
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".
===Exemplu 1===
<syntaxhighlight lang="python">
Introduceti un numar natural: 1230000
Datele de intrare corespund restrictiilor
Numarul de cifre egale cu zero ale numarului dat este: 4
</syntaxhighlight>


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".
===Exemplu 2===
<syntaxhighlight lang="python">
Introduceti un numar natural: -1230000
Datele de intrare nu corespund cerintei.
</syntaxhighlight>


== Rezolvare ==
===Exemplu 3===
<syntaxhighlight lang="python">
<syntaxhighlight lang="python">
def validate_n(n):
Introduceti un numar natural: 0
    if isinstance(n, int) and n >= 0:
Datele de intrare corespund restrictiilor
        return True
Numarul de cifre egale cu zero ale numarului dat este: 0
    else:
</syntaxhighlight>
        return False


def validate_nr(nr):
==Rezolvare==
     if isinstance(nr, int) and nr >= 0:
<syntaxhighlight lang="python">
        return True
def validare(n):
    else:
     if n < 0 or n >= 2000000000:
         return False
         return False
    return True


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


def main():
def main():
     n = input("Introduceti un numar intreg pozitiv: ")
     n = int(input("Introduceti un numar natural: "))
     try:
     if validare(n):
        n = int(n)
         print("Datele de intrare corespund restrictiilor")
         if validate_n(n):
        rezultat = nr_cif_zero(n, 0)
            nr = nr_cif_zero(n, 0)
        print("Numarul de cifre egale cu zero ale numarului dat este:", rezultat)
            if validate_nr(nr):
    else:
                print(f"Numarul de cifre 0 din numarul introdus este: {nr}")
        print("Datele de intrare nu corespund cerintei.")
            else:
 
                print("Numarul de cifre 0 obtinut nu este valid.")
if __name__ == '__main__':
        else:
    main()
            print("Numarul introdus nu este valid.")
 
    except ValueError:
        print("Nu ati introdus un numar intreg pozitiv.")
</syntaxhighlight>
</syntaxhighlight>
==Explicații ==
Funcția validare(n) primește ca parametru un număr n și verifică dacă acesta respectă restricțiile impuse de cerință (între 0 și 2 miliarde). Dacă da, returnează True, altfel returnează False.
Funcția nr_cif_zero(n, nr) primește ca parametri un număr n și o variabilă nr care va fi utilizată pentru a număra cifrele egale cu zero. Funcția este recursivă și verifică dacă ultima cifră a numărului este 0. Dacă da, incrementăm variabila nr. Apoi apelăm recursiv funcția pentru restul numărului împărțit la 10, astfel încât să putem analiza și următoarea cifră a numărului. Când n devine 0, înseamnă că am analizat toate cifrele numărului, așa că returnăm variabila nr care reprezintă numărul de cifre egale cu zero.
Funcția main() citește un număr natural n de la tastatură. Dacă acesta respectă restricțiile impuse, afișează un mesaj corespunzător și apelează funcția nr_cif_zero(n, 0) pentru a calcula numărul de cifre egale cu zero. Rezultatul este afișat la ecran. Dacă n nu respectă restricțiile impuse, afișăm un alt mesaj corespunzător.
Programul principal verifică dacă se rulează direct acest fișier (prin intermediul instrucțiunii if __name__ == '__main__':) și apelează funcția main().

Revision as of 18:07, 25 April 2023

Cerinţa

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.

Date de intrare

Se va introduce de la tastatură un număr natural care va fi transmis ca perimetru

Date de ieșire

Dacă datele de intrare corespund restrictiilor impuse se va afișa mesajul "Datele de intrare corespund restricțiilor" și pe un rând nou se afișează ceea ce se cere. Altfel, dacă datele de intrare nu corespund cerinței se va afișa mesajul: "Datele de intrare nu corespund cerinței".

Restricţii şi precizări

  • 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

Exemplu

Exemplu 1

<syntaxhighlight lang="python">

Introduceti un numar natural: 1230000 Datele de intrare corespund restrictiilor Numarul de cifre egale cu zero ale numarului dat este: 4 </syntaxhighlight>

Exemplu 2

<syntaxhighlight lang="python">

Introduceti un numar natural: -1230000 Datele de intrare nu corespund cerintei. </syntaxhighlight>

Exemplu 3

<syntaxhighlight lang="python">

Introduceti un numar natural: 0 Datele de intrare corespund restrictiilor Numarul de cifre egale cu zero ale numarului dat este: 0 </syntaxhighlight>

Rezolvare

<syntaxhighlight lang="python">

def validare(n):

   if n < 0 or n >= 2000000000:
       return False
   return True

def nr_cif_zero(n, nr):

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

def main():

   n = int(input("Introduceti un numar natural: "))
   if validare(n):
       print("Datele de intrare corespund restrictiilor")
       rezultat = nr_cif_zero(n, 0)
       print("Numarul de cifre egale cu zero ale numarului dat este:", rezultat)
   else:
       print("Datele de intrare nu corespund cerintei.")

if __name__ == '__main__':

   main()

</syntaxhighlight>

Explicații

Funcția validare(n) primește ca parametru un număr n și verifică dacă acesta respectă restricțiile impuse de cerință (între 0 și 2 miliarde). Dacă da, returnează True, altfel returnează False.

Funcția nr_cif_zero(n, nr) primește ca parametri un număr n și o variabilă nr care va fi utilizată pentru a număra cifrele egale cu zero. Funcția este recursivă și verifică dacă ultima cifră a numărului este 0. Dacă da, incrementăm variabila nr. Apoi apelăm recursiv funcția pentru restul numărului împărțit la 10, astfel încât să putem analiza și următoarea cifră a numărului. Când n devine 0, înseamnă că am analizat toate cifrele numărului, așa că returnăm variabila nr care reprezintă numărul de cifre egale cu zero.

Funcția main() citește un număr natural n de la tastatură. Dacă acesta respectă restricțiile impuse, afișează un mesaj corespunzător și apelează funcția nr_cif_zero(n, 0) pentru a calcula numărul de cifre egale cu zero. Rezultatul este afișat la ecran. Dacă n nu respectă restricțiile impuse, afișăm un alt mesaj corespunzător.

Programul principal verifică dacă se rulează direct acest fișier (prin intermediul instrucțiunii if __name__ == '__main__':) și apelează funcția main().