1633 - Dublare1

From Bitnami MediaWiki

Cerință

Să se scrie o funcție Python care să determine prima și ultima cifră a unui număr natural transmis ca parametru. Funcția va întoarce rezultatele prin intermediul unor parametri de ieşire.

Restricții de precizări

  • 1 ≤ n ≤ 10.000.000
  • funcția va avea un singur parametru n
  • numele funcției va fi dublare1

Exemplul 1

Dacă n are valoarea 85412, după apelul dublare1(n), n va fi 885412.

Explicatie

Prima cifră 8 se scrie de două ori.


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.


Rezolvare

Rezolvare ver. 1

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

def dublare1(n):

   if not 1 <= n <= 10000000:
       raise ValueError("Numarul trebuie sa fie intre 1 si 10.000.000")
   if n < 10:  # numarul are o singura cifra
       n *= 2
   else:
       cifra = str(n)[0]  # convertim numarul la sir de caractere si preluam prima cifra
       n = int(cifra * 2 + str(n)[1:])  # concatenam de doua ori cifra cu restul numarului si il convertim la int
   return n

def main():

   n = int(input("Introduceti un numar intreg: "))
   print("Numarul inainte de dublare: ", n)
   try:
       n = dublare1(n)
       print("Numarul dupa dublare: ", n)
   except ValueError as ve:
       print(ve)

if __name__ == "__main__":

   main()


</syntaxhighlight>