0826 - CifMinParRec: Difference between revisions
Catalin Moje (talk | contribs) No edit summary |
Catalin Moje (talk | contribs) No edit summary |
||
(One intermediate revision by the same user not shown) | |||
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=== | ||
: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 | ||
;Cea mai mică cifră pară din 2355235 este 2. | |||
===Exemplu 2=== | ===Exemplu 2=== | ||
:Intrare: | |||
Introduceți un număr natural: -10 | ;Introduceți un număr natural: -10 | ||
Datele de intrare nu corespund cerinței | :Iesire | ||
;Datele de intrare nu corespund cerinței | |||
===Exemplu 3=== | ===Exemplu 3=== | ||
:Intrare: | |||
Datele de intrare corespund restricțiilor | ;Datele de intrare corespund restricțiilor | ||
-1 | ;-1 | ||
==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): | ||
Line 57: | Line 58: | ||
#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> | </syntaxhighlight> | ||
==Explicații== | ==Explicații== |
Latest revision as of 21:17, 14 May 2023
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ă.