0826 - CifMinParRec: Difference between revisions

From Bitnami MediaWiki
No edit summary
 
Line 9: Line 9:


==Restricţii şi precizări==
==Restricţii şi precizări==
numele funcției va fi <code>cifminpar</code>
*numele funcției va fi <code>cifminpar</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 minimă pară va fi mai mic decât <code>2.000.000.000</code>
*numărul pentru care se calculează cifra minimă pară va fi mai mic decât <code>2.000.000.000</code>
dacă numărul nu conţine nici o cifră pară, se va returna valoarea <code>-1</code>
*dacă numărul nu conţine nici o cifră pară, se va returna valoarea <code>-1</code>


==Exemplu==
==Exemplu==
===Exemplu 1===
===Exemplu 1===
<syntaxhighlight lang="python" line>
:Intrare:
Introduceți un număr natural: 2355235
;Introduceți un număr natural: 2355235
Datele de intrare corespund restricțiilor
:Iesrire:
Cea mai mică cifră pară din 2355235 este 2.
;Datele de intrare corespund restricțiilor
</syntaxhighlight>
;Cea mai mică cifră pară din 2355235 este 2.
 
===Exemplu 2===
===Exemplu 2===
<syntaxhighlight lang="python" line>
:Intrare:
Introduceți un număr natural: -10
;Introduceți un număr natural: -10
Datele de intrare nu corespund cerinței
:Iesire
</syntaxhighlight>
;Datele de intrare nu corespund cerinței
 
===Exemplu 3===
===Exemplu 3===
<syntaxhighlight lang="python" line>
:Intrare:
Datele de intrare corespund restricțiilor
;Datele de intrare corespund restricțiilor
-1
;-1
</syntaxhighlight>
==Important==
==Important==
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.
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==
==Rezolvare==
<syntaxhighlight lang="python" line>
<syntaxhighlight lang="python" line="1">


def cifminpar(numar):
def cifminpar(numar):

Latest revision as of 21:17, 14 May 2023

Cerinţa[edit]

Să se scrie o python care să returneze cea mai mică cifră pară a unui număr natural transmis ca parametru.

Date de intrare[edit]

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

Date de ieșire[edit]

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]

  • numele funcției va fi cifminpar
  • funcția va avea un parametru reprezentând numărul dat
  • numărul pentru care se calculează cifra minimă pară va fi mai mic decât 2.000.000.000
  • dacă numărul nu conţine nici o cifră pară, se va returna valoarea -1

Exemplu[edit]

Exemplu 1[edit]

Intrare:
Introduceți un număr natural
2355235
Iesrire:
Datele de intrare corespund restricțiilor
Cea mai mică cifră pară din 2355235 este 2.

Exemplu 2[edit]

Intrare:
Introduceți un număr natural
-10
Iesire
Datele de intrare nu corespund cerinței

Exemplu 3[edit]

Intrare:
Datele de intrare corespund restricțiilor
-1

Important[edit]

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]

<syntaxhighlight lang="python" line="1">

def cifminpar(numar):

   if numar < 0 or numar >= 2000000000:
       return "Datele de intrare nu corespund cerinței"
   elif numar % 2 == 0:
       return "Cea mai mică cifră pară din " + str(numar) + " este " + str(min([int(cifra) for cifra in str(numar) if int(cifra) % 2 == 0]))
   else:
       if any(int(cifra) % 2 == 0 for cifra in str(numar)):
           return "Cea mai mică cifră pară din " + str(numar) + " este " + str(min([int(cifra) for cifra in str(numar) if int(cifra) % 2 == 0]))
       else:
           return -1

numar = int(input("Introduceți un număr natural: ")) rezultat = cifminpar(numar) if rezultat == "Datele de intrare nu corespund cerinței":

   print(rezultat)

else:

   print("Datele de intrare corespund restricțiilor")
   print(rezultat)


#Această funcție va solicita utilizatorului să introducă un număr natural, va apela funcția cifminpar și va afișa rezultatul. Dacă funcția cifminpar întoarce o valoare non-numerică, aceasta va fi afișată direct în consolă.

</syntaxhighlight>

Explicații[edit]

Se definește o funcție numită ceamai_mica_cifra_para care primește ca argument un număr natural n. Se verifică dacă numărul n conține cifre pare: a. Se convertește numărul n într-un șir de caractere pentru a putea parcurge cifrele sale. b. Se parcurg cifrele șirului și se verifică dacă fiecare cifră este pară. c. Dacă se găsește cel puțin o cifră pară, se continuă cu următorul pas. d. Altfel, se returnează valoarea -1. Se parcurge din nou șirul format din cifrele numărului n, de data aceasta în ordine inversă. Se verifică dacă fiecare cifră este pară și se ține minte cea mai mică cifră pară găsită până acum. Se returnează cea mai mică cifră pară găsită.