0828 - Manna-Pnueli: Difference between revisions

From Bitnami MediaWiki
No edit summary
No edit summary
 
(One intermediate revision by the same user not shown)
Line 6: Line 6:


==Date de ieșire==
==Date de ieșire==
Pe ecran se va afișa mesajul: "Datele de intrare corespund restricțiilor impuse."
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".
În cazul în care datele introduse de la tastatură nu îndeplinesc cerințele enunțate, pe ecran se va afișa mesajul "Datele de intrare nu corespund restricțiilor impuse.".


==Restricţii şi precizări==
==Restricţii şi precizări==
numele funcției va fi <code>cifmax</code>
*numele funcției va fi <code>cifmax</code>
funcția va avea un parametru reprezentând numărul dat
*funcția va avea un parametru reprezentând numărul dat
numărul pentru care se calculează cifra maximă va fi mai mic decât 2.000.000.000
*numărul pentru care se calculează cifra maximă va fi mai mic decât 2.000.000.000


==Exemplu==
==Exemplu==
cifmax(2050) este 5.
===Exemplu 1===
:Intrare:
;Introduceti numarul: 2050
:Iesire:
;Datele de intrare corespund restricțiilor impuse.
;Cifra maxima este: 5
 
 
===Exemplu 2===
:Intrare:
;Introduceti numarul: 2000000000
:Iesire:
;Datele de intrare nu corespund restricțiilor impuse.
;Cifra maxima este: None


==Important==
==Important==
Line 21: Line 33:


==Rezolvare==
==Rezolvare==
def validare(numar):
<syntaxhighlight lang="python" line="1">
def validare(numar):
     if not isinstance(numar, int) or numar < 0 or numar >= 2000000000:
     if not isinstance(numar, int) or numar < 0 or numar >= 2000000000:
        print("Datele de intrare nu corespund restricțiilor impuse.")
         return False
         return False
    print("Datele de intrare corespund restricțiilor impuse.")
     return True
     return True
def cifmax(numar):
 
 
def cifmax(numar, print_message=True):
     if not validare(numar):
     if not validare(numar):
        if print_message:
            print("Datele de intrare nu corespund restricțiilor impuse.")
         return None
         return None
    if print_message:
        print("Datele de intrare corespund restricțiilor impuse.")
     if numar < 10:
     if numar < 10:
         return numar
         return numar
     max_cifra = cifmax(numar // 10)
     max_cifra = cifmax(numar // 10, False)
     cifra_curenta = numar % 10
     cifra_curenta = numar % 10
     return max_cifra if max_cifra > cifra_curenta else cifra_curenta
     return max_cifra if max_cifra > cifra_curenta else cifra_curenta
def main():
 
 
def main():
     numar = int(input("Introduceti numarul: "))
     numar = int(input("Introduceti numarul: "))
     print("Cifra maxima este:", cifmax(numar))
     print("Cifra maxima este:", cifmax(numar))
if __name__ == '__main__':
 
 
if __name__ == '__main__':
     main()
     main()
</syntaxhighlight>


#Functia validare verifica daca numarul dat ca parametru este un intreg pozitiv si mai mic decat 2.000.000.000. Daca da, se afiseaza un mesaj corespunzator si se returneaza True, altfel se afiseaza alt mesaj si se returneaza False.
==Explicații==
#Functia cifmax primeste numarul dat ca parametru si, daca acesta a trecut validarea, incepe sa il parcurga recursiv, prin impartirea la 10 si apelarea functiei cu numarul rezultat. Cand numarul devine mai mic decat 10, se returneaza acesta. In fiecare apel, se compara cifra curenta cu cifra maxima gasita pana acum si se returneaza valoarea maxima dintre cele doua.
Funcția validare primește un parametru numar și verifică dacă acesta este un întreg pozitiv (mai mare sau egal cu 0) și mai mic decât 2000000000 (adica, intră în intervalul [0, 2000000000)).
#Functia main citeste numarul de la tastatura si apeleaza functia cifmax, afisand rezultatul gasit.
Funcția cifmax primește, de asemenea, un parametru numar, care reprezintă numărul la care se caută cifra maximă, și un parametru opțional print_message care indică dacă trebuie afișat mesajul "Datele de intrare corespund restricțiilor impuse." la apelul inițial al funcției. La început, parametrul print_message este setat la True.
În funcția cifmax, se verifică dacă numar este valid folosind funcția validare. Dacă numar nu este valid, funcția va afișa mesajul "Datele de intrare nu corespund restricțiilor impuse." dacă parametrul print_message este setat la True și va returna None.
Dacă numar este valid, funcția va afișa mesajul "Datele de intrare corespund restricțiilor impuse." la apelul inițial al funcției dacă print_message este setat la True.
Dacă numar are doar o cifră, acea cifră va fi returnată.
În caz contrar, se calculează cifra curentă și se face o apelare recursivă a funcției cifmax cu numărul format din toate cifrele lui numar cu excepția celei mai din dreapta (adică cu o cifră mai puțin), și parametrul print_message setat la False. Rezultatul apelului recursive este stocat în variabila max_cifra.
Dacă max_cifra este mai mare decât cifra curentă, atunci max_cifra este returnată. În caz contrar, cifra curentă este returnată.
Funcția main citește un număr de la tastatură, apelează funcția cifmax și afișează cifra maximă găsită.

Latest revision as of 21:25, 14 May 2023

Cerinţa[edit | edit source]

Să se scrie o python care să returneze cifra cifra maximă a unui număr natural transmis ca parametru.

Date de intrare[edit | edit source]

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

Date de ieșire[edit | edit source]

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[edit | edit source]

  • numele funcției va fi cifmax
  • funcția va avea un parametru reprezentând numărul dat
  • numărul pentru care se calculează cifra maximă va fi mai mic decât 2.000.000.000

Exemplu[edit | edit source]

Exemplu 1[edit | edit source]

Intrare:
Introduceti numarul
2050
Iesire:
Datele de intrare corespund restricțiilor impuse.
Cifra maxima este
5


Exemplu 2[edit | edit source]

Intrare:
Introduceti numarul
2000000000
Iesire:
Datele de intrare nu corespund restricțiilor impuse.
Cifra maxima este
None

Important[edit | edit source]

Soluţia propusă va conţine doar definiţia funcţiei cerute. Prezenţa în soluţie a altor instrucţiuni poate duce erori de compilare sau de execuţie care vor avea ca efect depunctarea soluţiei.

Rezolvare[edit | edit source]

<syntaxhighlight lang="python" line="1"> def validare(numar):

   if not isinstance(numar, int) or numar < 0 or numar >= 2000000000:
       return False
   return True


def cifmax(numar, print_message=True):

   if not validare(numar):
       if print_message:
           print("Datele de intrare nu corespund restricțiilor impuse.")
       return None
   if print_message:
       print("Datele de intrare corespund restricțiilor impuse.")
   if numar < 10:
       return numar
   max_cifra = cifmax(numar // 10, False)
   cifra_curenta = numar % 10
   return max_cifra if max_cifra > cifra_curenta else cifra_curenta


def main():

   numar = int(input("Introduceti numarul: "))
   print("Cifra maxima este:", cifmax(numar))


if __name__ == '__main__':

   main()

</syntaxhighlight>

Explicații[edit | edit source]

Funcția validare primește un parametru numar și verifică dacă acesta este un întreg pozitiv (mai mare sau egal cu 0) și mai mic decât 2000000000 (adica, intră în intervalul [0, 2000000000)). Funcția cifmax primește, de asemenea, un parametru numar, care reprezintă numărul la care se caută cifra maximă, și un parametru opțional print_message care indică dacă trebuie afișat mesajul "Datele de intrare corespund restricțiilor impuse." la apelul inițial al funcției. La început, parametrul print_message este setat la True. În funcția cifmax, se verifică dacă numar este valid folosind funcția validare. Dacă numar nu este valid, funcția va afișa mesajul "Datele de intrare nu corespund restricțiilor impuse." dacă parametrul print_message este setat la True și va returna None. Dacă numar este valid, funcția va afișa mesajul "Datele de intrare corespund restricțiilor impuse." la apelul inițial al funcției dacă print_message este setat la True. Dacă numar are doar o cifră, acea cifră va fi returnată. În caz contrar, se calculează cifra curentă și se face o apelare recursivă a funcției cifmax cu numărul format din toate cifrele lui numar cu excepția celei mai din dreapta (adică cu o cifră mai puțin), și parametrul print_message setat la False. Rezultatul apelului recursive este stocat în variabila max_cifra. Dacă max_cifra este mai mare decât cifra curentă, atunci max_cifra este returnată. În caz contrar, cifra curentă este returnată. Funcția main citește un număr de la tastatură, apelează funcția cifmax și afișează cifra maximă găsită.