0834 - ElimCifRec

From Bitnami MediaWiki

Cerinţa

Să se scrie o python care primește ca parametrii un număr natural n și o cifră c și returnează numărul obținut prin eliminarea din n a tuturor aparițiilor lui c.

Date de intrare

Se va introduce de la tastatură un număr natural care va fi transmis ca perimetru

Date de ieșire

Dacă datele de intrare corespund restrictiilor impuse se va afișa mesajul "Datele de intrare corespund restricțiilor" și pe un rând nou se afișează ceea ce se cere. Altfel, dacă datele de intrare nu corespund cerinței se va afișa mesajul: "Datele de intrare nu corespund cerinței".


Restricţii şi precizări

  • numele funcției va fi elimcif
  • funcția va avea doi parametri, în această ordine: n, c, cu semnificația de mai sus
  • 1 ≤ n ≤ 2.000.000.000, 0 ≤ c < 10

Exemplu

Exemplu 1

Intrare:
Introduceti un numar natural
2454
Introduceti cifra
4
Iesire:
Datele de intrare corespund restrictiilor
Numarul obtinut prin eliminarea cifrei 4 din 0 este 25

Exemplu 2

Intrare:
Introduceti un numar natural
1157
Introduceti cifra
8
Iesire:
Datele de intrare corespund restrictiilor
Numarul obtinut prin eliminarea cifrei 8 din 0 este 1157

Exemplu 3

Intrare:
Introduceti un numar natural
abc
Iesire:
Datele de intrare nu corespund restricțiilor impuse.

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

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

def validare(n, c):
   if not isinstance(n, int) or not isinstance(c, int):
       return False
   if n < 1 or n > 2000000000 or c < 0 or c > 9:
       return False
   return True

def elimcif(n, c):

   if not validare(n, c):
       print("Datele de intrare nu corespund cerintei")
       return
   numar_nou = 0
   putere = 1
   while n > 0:
       ultima_cifra = n % 10
       if ultima_cifra != c:
           numar_nou += ultima_cifra * putere
           putere *= 10
       n //= 10
   if numar_nou == 0:
       print("Numarul nu contine cifre diferite de", c)
   else:
       print("Datele de intrare corespund restrictiilor")
       print("Numarul obtinut prin eliminarea cifrei", c, "din", n, "este", numar_nou)

def main():

   n = int(input("Introduceti un numar natural: "))
   c = int(input("Introduceti cifra: "))
   elimcif(n, c)

if __name__ == "__main__":

   main()

</syntaxhighlight>

Explicații

Funcția validare verifică dacă datele de intrare respectă restricțiile cerute. Dacă n este mai mare decât 2 miliarde sau cifra c nu este între 0 și 9, funcția va returna False, altfel va returna True.

Funcția elimcif primește doi parametri: n și c. În interiorul acestei funcții, se verifică dacă datele de intrare corespund cerințelor folosind funcția de validare și se afișează mesajul corespunzător. Dacă datele sunt corecte, se realizează eliminarea cifrei c din numărul n.

Mai întâi, convertim numărul n într-un șir de caractere folosind funcția str. Apoi, într-un for loop, iterăm prin toate caracterele șirului și adăugăm într-un alt șir doar caracterele diferite de cifra c. La final, convertim șirul obținut într-un număr întreg folosind funcția int.

În funcția main, se citește numărul de la tastatură, se verifică dacă datele de intrare corespund cerințelor folosind funcția de validare, iar dacă da, se apelează funcția elimcif și se afișează rezultatul.