3665 - CMMCP: Difference between revisions

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


<syntaxhighlight lang="python" line>
<syntaxhighlight lang="python" line>
def verificare_restricții(număr1):
def verificare_restricții(număr):
     #Verifică dacă numărul dat respectă restricțiile impuse.
     #Verifică dacă numărul este între 0 și 1.000.000.000.000
     if număr1 < 0 or număr1 > 1000000000000:
 
     if număr < 0 or număr > 1000000000000:
         return False
         return False
     return True
     else:
        return True


def rezolvare_problema(număr1):
def rezolvare_problema(număr):
    maxim = 0 # inițializăm maximul cu o valoare nesemnificativă


     if număr1 == 0:
     maxim = 10 # inițializăm maximul cu 10
        maxim = 0


    # parcurgem cifrele numărului și găsim cea mai mare cifră pară
     while număr != 0:
     while număr1 != 0:
         cifră = număr % 10 # extragem ultima cifră
         if maxim == 10: # dacă nu am găsit încă nicio cifră pară, maximul primește valoarea primei cifre pare
        if cifră % 2 == 0 and cifră > maxim: # dacă este pară și mai mare decât maximul curent
            if număr1 % 2 == 0:
             maxim = cifră # actualizăm maximul
                maxim = număr1 % 10
         număr //= 10 # eliminăm ultima cifră
        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:
     return maxim
        return 10
    else:
        return maxim


if __name__ == "__main__":
if __name__ == "__main__":
     număr1 = int(input("Introduceți numărul: "))
 
     if verificare_restricții(număr1):
     număr = int(input("Introduceți numărul: "))
 
     if verificare_restricții(număr):
         print("Datele sunt introduse corect.")
         print("Datele sunt introduse corect.")
         rezultat = rezolvare_problema(număr1)
         maxim_păr = rezolvare_problema(număr)
         print("Cea mai mare cifră pară din număr este:", rezultat)
         if maxim_păr == 10:
            print("Numărul nu conține cifre pare.")
        else:
            print("Cea mai mare cifră pară a numărului este:", maxim_păr)
     else:
     else:
         print("Datele nu au fost introduse corect.")
         print("Datele nu au fost introduse corect.")




</syntaxhighlight>
</syntaxhighlight>

Revision as of 19:16, 26 April 2023

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, se va afișa "Datele sunt introduse corect.", apoi se va afișa pe ecran cea mai mare cifră pară a numărului introdus. Î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> def verificare_restricții(număr):

   #Verifică dacă numărul este între 0 și 1.000.000.000.000
   if număr < 0 or număr > 1000000000000:
       return False
   else:
       return True

def rezolvare_problema(număr):

   maxim = 10 # inițializăm maximul cu 10
   while număr != 0:
       cifră = număr % 10 # extragem ultima cifră
       if cifră % 2 == 0 and cifră > maxim: # dacă este pară și mai mare decât maximul curent
           maxim = cifră # actualizăm maximul
       număr //= 10 # eliminăm ultima cifră
   return maxim

if __name__ == "__main__":

   număr = int(input("Introduceți numărul: "))
   if verificare_restricții(număr):
       print("Datele sunt introduse corect.")
       maxim_păr = rezolvare_problema(număr)
       if maxim_păr == 10:
           print("Numărul nu conține cifre pare.")
       else:
           print("Cea mai mare cifră pară a numărului este:", maxim_păr)
   else:
       print("Datele nu au fost introduse corect.")



</syntaxhighlight>