3349 - Putere1: Diferență între versiuni

De la Universitas MediaWiki
(Pagină nouă: == Cerință == Se dau numerele naturale b n p. Determinați numărul format din ultimele p cifre ale lui bn. == Date de intrare == Programul citește de la tastatură numerele b n p. == Date de ieșire == Programul va afișa pe ecran numărul format din ultimele p cifre ale lui bn. == Restricții de precizări == *1 ⩽ b ⩽ 1000000000 *1 ⩽ n ⩽ 2^31 *1 ⩽ p ⩽ 9 == Exemplul 1== ; Intrare : 2 : 10 : 2 ; Ieșire : Datele introduse corespund restricțiilor im...)
 
Fără descriere a modificării
 
(Nu s-au afișat 5 versiuni intermediare efectuate de alți 2 utilizatori)
Linia 1: Linia 1:
== Cerință ==
== Cerință ==
Se dau numerele naturale b n p. Determinați numărul format din ultimele p cifre ale lui bn.
Se dau numerele naturale '''b n p'''. Determinați numărul format din ultimele '''p''' cifre ale lui <math>b^n</math>.
== Date de intrare ==
== Date de intrare ==
Programul citește de la tastatură numerele b n p.
Programul citește de la tastatură numerele '''b n p'''.
== Date de ieșire ==
== Date de ieșire ==
Programul va afișa pe ecran numărul format din ultimele p cifre ale lui bn.
Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele de intrare corespund restricțiilor impuse." și programul va afișa pe ecran numărul format din ultimele p cifre ale lui <math>b^n</math>. În caz contrar, se va afișa pe ecran: "Datele de intrare nu corespund restricțiilor impuse."
 
== Restricții de precizări ==
== Restricții de precizări ==
*1 &les; b &les; 1000000000
*1 &les; '''b'''  &les; 1000000000
*1 &les; n &les; 2^31
*1 &les; '''n'''  &les; 2^31
*1 &les; p &les; 9
*1 &les; '''p''' &les; 9
== Exemplul 1==
==Exemplu==
=== Exemplul 1===
; Intrare
; Intrare
: 2
: 2
Linia 17: Linia 19:
: Datele introduse corespund restricțiilor impuse.
: Datele introduse corespund restricțiilor impuse.
: 24
: 24
<br>
=== Exemplul 2 ===
== Exemplul 2 ==
; Intrare
; Intrare
: 123456789
: 123456789
Linia 25: Linia 26:
; Ieșire
; Ieșire
: Datele introduse corespund restricțiilor impuse.
: Datele introduse corespund restricțiilor impuse.
: 521
: 949
<br>
==Rezolvare==
== Rezolvare ==
=== Rezolvare vers. 1 ===
<syntaxhighlight lang="python" line="1" start="1">
def validare(b, n, p):
    # Verifică dacă b, n și p sunt formate doar din cifre și dacă respectă restricțiile impuse
    return b.isdigit() and 1 <= int(b) <= 1000000000 and n.isdigit() and 1 <= int(n) <= 2 ** 31 and p.isdigit() and 1 <= int(p) <= 9
 
 
def putere(b, n, p):
    result = str(b ** n)[-p:]  # Calculează rezultatul final ca ultimele p cifre din rezultatul b la puterea n
    print(int(result))
 
 
if __name__ == '__main__':
    b = input("Introduceti numarul b: ")
    n = input("Introduceti puterea n: ")
    p = input("Introduceti numarul de cifre dorit: ")
    if validare(b, n, p):
        b, n, p = int(b), int(n), int(p)
        print("Datele introduse corespund restricțiilor impuse.")
        putere(b, n, p)  # Afișează rezultatul final
    else:
        print("Datele introduse nu corespund restricțiilor impuse.")
 
</syntaxhighlight>

Versiunea curentă din 25 aprilie 2023 08:41

Cerință

Se dau numerele naturale b n p. Determinați numărul format din ultimele p cifre ale lui .

Date de intrare

Programul citește de la tastatură numerele b n p.

Date de ieșire

Dacă datele sunt introduse corect, pe ecran se va afișa: "Datele de intrare corespund restricțiilor impuse." și programul va afișa pe ecran numărul format din ultimele p cifre ale lui . În caz contrar, se va afișa pe ecran: "Datele de intrare nu corespund restricțiilor impuse."

Restricții de precizări

  • 1 ⩽ b ⩽ 1000000000
  • 1 ⩽ n ⩽ 2^31
  • 1 ⩽ p ⩽ 9

Exemplu

Exemplul 1

Intrare
2
10
2
Ieșire
Datele introduse corespund restricțiilor impuse.
24

Exemplul 2

Intrare
123456789
5
3
Ieșire
Datele introduse corespund restricțiilor impuse.
949

Rezolvare

Rezolvare vers. 1

def validare(b, n, p):
    # Verifică dacă b, n și p sunt formate doar din cifre și dacă respectă restricțiile impuse
    return b.isdigit() and 1 <= int(b) <= 1000000000 and n.isdigit() and 1 <= int(n) <= 2 ** 31 and p.isdigit() and 1 <= int(p) <= 9


def putere(b, n, p):
    result = str(b ** n)[-p:]  # Calculează rezultatul final ca ultimele p cifre din rezultatul b la puterea n
    print(int(result))


if __name__ == '__main__':
    b = input("Introduceti numarul b: ")
    n = input("Introduceti puterea n: ")
    p = input("Introduceti numarul de cifre dorit: ")
    if validare(b, n, p):
        b, n, p = int(b), int(n), int(p)
        print("Datele introduse corespund restricțiilor impuse.")
        putere(b, n, p)  # Afișează rezultatul final
    else:
        print("Datele introduse nu corespund restricțiilor impuse.")