0894 - CifMinMax

From Bitnami MediaWiki

Cerinţa

Să se scrie o funcție Python care să determine cea mai mare și cea mai mică cifră a unui număr natural transmis ca parametru. Funcția va întoarce rezultatele prin intermediul unor parametri de ieşire.

Restricţii şi precizări

  • numele funcției va fi cifminmax
  • funcția va avea trei parametri: primul parametru reprezintă numărul pentru care se calculează valorile cerute;al doilea parametru va reprezenta cifra maximă, iar al treilea va reprezenta cifra minimă
  • numărul pentru care se calculează cele doua valori va fi mai mic decât 2.000.000.000

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: "Date de intrare valide.", apoi pe un rând nou cea mai mare și cea mai mică cifră din numărul introdus. În cazul în care numărul introdus depășește limitele date, se va afișa "Date de intrare invalide."

Exemplu

Intrare
12345
Ieșire
Date de intrare valide
Cea mai mare cifra este: 5
Cea mai mica cifra este: 1

Rezolvare

<syntaxhighlight lang="python"> def validate_cifminmax(n, max_cif, min_cif):

   if n >= 2000000000:
       return False
   return True


def cifminmax(n, max_cif, min_cif):

   while n > 0:
       cif = n % 10
       if cif > max_cif:
           max_cif = cif
       if cif < min_cif:
           min_cif = cif
       n //= 10
   return max_cif, min_cif


if __name__ == '__main__':

   n = 123456789
   max_cif = -1
   min_cif = 10
   if validate_cifminmax(n, max_cif, min_cif):
       print("Date de intrare valide")
       max_cif, min_cif = cifminmax(n, max_cif, min_cif)
       print("Cea mai mare cifra este:", max_cif)
       print("Cea mai mica cifra este:", min_cif)
   else:
       print("Date de intrare invalide")

</syntaxhighlight>

Explicație

Acest cod definește trei funcții și verifică dacă datele de intrare sunt valide pentru a calcula cea mai mare și cea mai mică cifră a unui număr dat.

Funcția `validate_cifminmax` primește trei argumente: `n`, `max_cif`, și `min_cif`. Funcția verifică dacă valoarea `n` este mai mică decât 2000000000 și returnează `True` dacă da, `False` în caz contrar. Această funcție este folosită pentru a verifica dacă numărul dat este un număr valid, adică dacă acesta este mai mic decât 2 miliarde.

Funcția `cifminmax` primește trei argumente: `n`, `max_cif`, și `min_cif`. Această funcție calculează cea mai mare și cea mai mică cifră a lui `n`. Se începe prin a atribui `max_cif` o valoare inițială de -1 și `min_cif` o valoare inițială de 10. Apoi, folosind un ciclu `while`, se extrage fiecare cifră a lui `n` prin împărțirea lui `n` la 10 și reținerea restului. Dacă cifra extrasă este mai mare decât valoarea curentă a lui `max_cif`, aceasta devine noua valoare a lui `max_cif`. Dacă cifra extrasă este mai mică decât valoarea curentă a lui `min_cif`, aceasta devine noua valoare a lui `min_cif`. La sfârșitul ciclului, funcția returnează cele două valori `max_cif` și `min_cif`.

În `main` se inițializează variabilele `n`, `max_cif` și `min_cif`. Apoi, se verifică dacă datele de intrare sunt valide apelând funcția `validate_cifminmax`. Dacă datele sunt valide, se afișează un mesaj corespunzător, se calculează cea mai mare și cea mai mică cifră a lui `n` folosind funcția `cifminmax`, și se afișează rezultatele. Dacă datele de intrare nu sunt valide, se afișează un alt mesaj.