4212 - Inc Cif Pare: Difference between revisions

From Bitnami MediaWiki
Pagină nouă: == Cerinţa == Să se scrie un program care citește un număr natural n și care crește cu 1 valoarea cifrelor pare. De exemplu, dacă '''n=1234''' atunci se va obține numărul '''1335''', iar dacă '''n=135''' atunci numărul rămâne neschimbat. == Date de intrare == Programul citește de la tastatură numărul '''n'''. == Date de ieşire == Programul va afișa pe ecran numărul obținut prin creșterea cu '''1''' a cifrelor pare ale lui '''n'''. == Restricții și preci...
 
No edit summary
 
(3 intermediate revisions by the same user not shown)
Line 7: Line 7:
== Restricții și precizări ==
== Restricții și precizări ==
* 0 ⩽ n ⩽ 1.000.000.000
* 0 ⩽ n ⩽ 1.000.000.000
== Exemplu ==
== Exemplul 1 ==
; Intrare
; Intrare
; 1234
: 1234
; Ieșire
; Ieșire
; 1335
: Datele introduse corespund restricțiilor impuse.
: 1335
<br>
== Exemplul 2 ==
; Intrare
: 13n2
; Ieșire
: Datele de intrare nu corespund restricțiilor impuse.
<br>
== Rezolvare ==
== Rezolvare ==
<syntaxhighlight lang="python" line>
<syntaxhighlight lang="python" line>
# Definim funcția pentru cifrele pare
# 4212 Inc Cif Pare
def problema_4212(n):
 
     n = str(n)
# Definim funcția de verificare a valorii n
 
 
def verificare(n_val):
    # Verificăm dacă n respectă restricțiile problemei
    if 0 <= n_val <= 1000000000:
        # Dacă valoarea este validă, returnăm valoarea
        return n_val
    else:
        # Dacă valoarea nu este validă, ridicăm o excepție
        raise ValueError
 
 
def cifre_pare(numar):
     # Convertim numărul la string pentru a putea itera prin cifre
    numar = str(numar)
     rezultat = ''
     rezultat = ''
     for cifra in n:
     for cifra in numar:
         # Verificăm dacă cifra este pară
         # Verificăm dacă cifra este pară
         if int(cifra) % 2 == 0:
         if int(cifra) % 2 == 0:
             #Dacă cifra este pară, o creștem cu 1 și o adăugăm la rezultat
             # Dacă cifra este pară, o creștem cu 1 și o adăugăm la rezultat
             rezultat += str(int(cifra) + 1)
             rezultat += str(int(cifra) + 1)
         else:
         else:
             # Dacă cifra este pară, o creștem cu 1 și o adăugăm la rezultat
             # Dacă cifra este impară, o adăugăm la rezultat
             rezultat += cifra
             rezultat += cifra
     # Convertim rezultatul înapoi în număr și îl returnăm
     # Convertim rezultatul înapoi în număr și îl returnăm
     return int(rezultat)
     return int(rezultat)


# Verificăm codul cu cele doua numere
 
# Verificăm dacă acest script este rulat direct
if __name__ == "__main__":
if __name__ == "__main__":
     n = 1234
     try:
    n1 = 135
        # Citim numărul de la utilizator
    print(problema_4212(n))
        n = input("Introduceti un numar: ")
     print(problema_4212(n1))
        # Validăm numărul
        n = verificare(int(n))
        # Dacă numărul este valid, rezolvăm problema
        print("Datele introduse corespund restricțiilor impuse.")
        print(cifre_pare(n))
     except ValueError:
        # Dacă numărul nu este valid, afișăm un mesaj de eroare
        print("Datele introduse nu corespund restricțiilor impuse.")
    except Exception as e:
        # Dacă se produce o excepție, o afișăm
        print(str(e))


</syntaxhighlight>
</syntaxhighlight>

Latest revision as of 19:11, 10 November 2023

Cerinţa[edit | edit source]

Să se scrie un program care citește un număr natural n și care crește cu 1 valoarea cifrelor pare. De exemplu, dacă n=1234 atunci se va obține numărul 1335, iar dacă n=135 atunci numărul rămâne neschimbat.

Date de intrare[edit | edit source]

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

Date de ieşire[edit | edit source]

Programul va afișa pe ecran numărul obținut prin creșterea cu 1 a cifrelor pare ale lui n.

Restricții și precizări[edit | edit source]

  • 0 ⩽ n ⩽ 1.000.000.000

Exemplul 1[edit | edit source]

Intrare
1234
Ieșire
Datele introduse corespund restricțiilor impuse.
1335


Exemplul 2[edit | edit source]

Intrare
13n2
Ieșire
Datele de intrare nu corespund restricțiilor impuse.


Rezolvare[edit | edit source]

<syntaxhighlight lang="python" line>

  1. 4212 Inc Cif Pare
  1. Definim funcția de verificare a valorii n


def verificare(n_val):

   # Verificăm dacă n respectă restricțiile problemei
   if 0 <= n_val <= 1000000000:
       # Dacă valoarea este validă, returnăm valoarea
       return n_val
   else:
       # Dacă valoarea nu este validă, ridicăm o excepție
       raise ValueError


def cifre_pare(numar):

   # Convertim numărul la string pentru a putea itera prin cifre
   numar = str(numar)
   rezultat = 
   for cifra in numar:
       # Verificăm dacă cifra este pară
       if int(cifra) % 2 == 0:
           # Dacă cifra este pară, o creștem cu 1 și o adăugăm la rezultat
           rezultat += str(int(cifra) + 1)
       else:
           # Dacă cifra este impară, o adăugăm la rezultat
           rezultat += cifra
   # Convertim rezultatul înapoi în număr și îl returnăm
   return int(rezultat)


  1. Verificăm dacă acest script este rulat direct

if __name__ == "__main__":

   try:
       # Citim numărul de la utilizator
       n = input("Introduceti un numar: ")
       # Validăm numărul
       n = verificare(int(n))
       # Dacă numărul este valid, rezolvăm problema
       print("Datele introduse corespund restricțiilor impuse.")
       print(cifre_pare(n))
   except ValueError:
       # Dacă numărul nu este valid, afișăm un mesaj de eroare
       print("Datele introduse nu corespund restricțiilor impuse.")
   except Exception as e:
       # Dacă se produce o excepție, o afișăm
       print(str(e))

</syntaxhighlight>