0834 - ElimCifRec: Difference between revisions

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


Restricţii şi precizări
Restricţii şi precizări
numele funcției va fi elimcif
*numele funcției va fi elimcif
funcția va avea doi parametri, în această ordine: n, c, cu semnificația de mai sus
*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
*1 ≤ n ≤ 2.000.000.000, 0 ≤ c < 10


==Exemplu==
==Exemplu==
===Exemplu 1===
===Exemplu 1===
<syntaxhighlight lang="python" line>
:Intrare:
Introduceti un numar natural: 2454
;Introduceti un numar natural: 2454
Introduceti cifra: 4
;Introduceti cifra: 4
Datele de intrare corespund restrictiilor
:Iesire:
Numarul obtinut prin eliminarea cifrei 4 din 0 este 25
;Datele de intrare corespund restrictiilor
</syntaxhighlight>
;Numarul obtinut prin eliminarea cifrei 4 din 0 este 25
 
===Exemplu 2===
===Exemplu 2===
<syntaxhighlight lang="python" line>
:Intrare:
Introduceti un numar natural: 1157
;Introduceti un numar natural: 1157
Introduceti cifra: 8
;Introduceti cifra: 8
Datele de intrare corespund restrictiilor
:Iesire:
Numarul obtinut prin eliminarea cifrei 8 din 0 este 1157
;Datele de intrare corespund restrictiilor
</syntaxhighlight>
;Numarul obtinut prin eliminarea cifrei 8 din 0 este 1157
===Exemplu 3===
===Exemplu 3===
<syntaxhighlight lang="python">
:Intrare:
Introduceti un numar natural: abc  
;Introduceti un numar natural: abc
Datele de intrare nu corespund restricțiilor impuse.
:Iesire:
</syntaxhighlight>
;Datele de intrare nu corespund restricțiilor impuse.
 
==Important==
==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.
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.
Line 39: Line 41:


==Rezolvare==
==Rezolvare==
<syntaxhighlight lang="python" line>
<syntaxhighlight lang="python" line="1">
  def validare(n, c):
  def validare(n, c):
     if not isinstance(n, int) or not isinstance(c, int):
     if not isinstance(n, int) or not isinstance(c, int):

Latest revision as of 21:20, 14 May 2023

Cerinţa[edit]

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[edit]

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

Date de ieșire[edit]

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[edit]

Exemplu 1[edit]

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[edit]

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[edit]

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

Important[edit]

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[edit]

<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[edit]

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.