0826 - CifMinParRec

From Bitnami MediaWiki

Cerinţa[edit | edit source]

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

Exemplu 1[edit | edit source]

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

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

Exemplu 3[edit | edit source]

Intrare:
Datele de intrare corespund restricțiilor
-1

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

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ă.