2206 - Min Impar

From Bitnami MediaWiki

Cerinţa

Se dă un număr X. Să se afle cel mai mic număr Y ≥ X cu proprietatea că Y are doar cifre impare.

Date de intrare

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

Date de ieșire

Dacă datele sunt introduse corect, pe ecran: "Datele sunt introduse corect.",programul va afișa pe ecran numărul Y. În cazul în care datele nu respectă restricțiile, se va afișa: "Datele nu corespund restricțiilor impuse.".

Restricţii şi precizări

  • 1 ≤ X ≤ 10^18


Exemple

Exemplul 1

Intrare
22
Ieșire
31

Exemplul 2

Intrare
10
Ieșire
11

Exemplul 3

Intrare
-2
Ieșire
Datele nu corespund restricțiilor impuse.



Rezolvare

<syntaxhighlight lang="python" line="1">

  1. 2206 - Min Impar

def validare_date(x: int) -> bool:

   """
   Verifică dacă datele de intrare sunt valide conform cerințelor.
   """
   return 1 <= x <= 10 ** 18


def gaseste_numar_imp(x: int) -> int:

   """
   Găsește cel mai mic număr Y ≥ X cu proprietatea că Y are doar cifre impare.
   """
   while True:
       if all(int(d) % 2 == 1 for d in str(x)):
           return x
       x += 1


if __name__ == '__main__':

   x = int(input("Introduceți numărul X: "))
   if not validare_date(x):
       print("Datele nu corespund restricțiilor impuse.")
       exit()
   print("Datele sunt introduse corect.")
   y = gaseste_numar_imp(x)
   print(y)



</syntaxhighlight>

Explicatie

Funcția validare_date(x: int) -> bool: Această funcție verifică dacă numărul x primit ca argument se încadrează în intervalul [1, 10^18] și returnează True dacă acesta este valid și False altfel. Astfel, această funcție este folosită pentru a valida datele de intrare înainte de a executa funcția gaseste_numar_imp.

Funcția gaseste_numar_imp(x: int) -> int: Această funcție primește un număr x și începe să-l mărească treptat până când găsește cel mai mic număr Y care are doar cifre impare și Y este mai mare sau egal cu X. În fiecare iterație, funcția verifică dacă toate cifrele numărului curent sunt impare. Dacă este așa, atunci funcția returnează numărul curent, altfel continuă să-l mărească pe x cu o unitate și să reia verificarea.

Blocul if __name__ == '__main__':: Acest bloc verifică dacă acest script este rulat direct ca fișier executabil sau a fost importat în alt modul Python. În cazul în care acesta este rulat direct, atunci se solicită utilizatorului să introducă un număr întreg x și se validează acest număr folosind funcția validare_date. Dacă numărul este valid, atunci se calculează cel mai mic număr Y care are doar cifre impare și este mai mare sau egal cu X, folosind funcția gaseste_numar_imp. În cele din urmă, numărul Y este afișat pe ecran.