3665 - CMMCP

From Bitnami MediaWiki
Revision as of 17:11, 7 April 2023 by Tamas Claudia (talk | contribs)

Sursă: [1]

Cerința

Se dă un număr natural număr1. Determinaţi cea mai mare cifră pară a sa. Dacă numărul nu are cifre pare se va afişa numărul 10.

Date de intrare

Programul citește de la tastatură numărul număr1.

Date de ieșire

Dacă datele sunt introduse corect, pe ecran se va afișa "Datele sunt introduse corect.", apoi se va afișa pe ecran valoarea cerută. în caz contrar, se va afișa pe ecran. "Datele nu au fost introduse corect".

Restricții și precizări

  • 0 ⩽ număr1 ⩽ 1.000.000.000.000

Exemplu

Intrare
1440
Ieșire
4


Rezolvare

<syntaxhighlight lang="python" line> număr1 = int(input("Introduceți numărul: ")) # citim numărul de la tastatură

  1. verificăm restricțiile impuse asupra numărului

if număr1 < 0 or număr1 > 1000000000000:

   print("Datele nu au fost introduse corect")

else:

   maxim = 0 # inițializăm maximul cu o valoare nesemnificativă
   if număr1 == 0:
       maxim = 0
   # parcurgem cifrele numărului și găsim cea mai mare cifră pară
   while număr1 != 0:
       if maxim == 10: # dacă nu am găsit încă nicio cifră pară, maximul primește valoarea primei cifre pare
           if număr1 % 2 == 0:
               maxim = număr1 % 10
       else: # dacă am găsit deja o cifră pară, maximul se actualizează doar dacă găsim o cifră pară mai mare decât cea actuală
           if număr1 % 10 > maxim and număr1 % 2 == 0:
               maxim = număr1 % 10
       număr1 = număr1 // 10 # trecem la următoarea cifră
   if maxim == 10:
       print("Numărul nu conține cifre pare")
   else:
       print("Cea mai mare cifră pară din număr este:", maxim)


</syntaxhighlight>