3349 - Putere1: Difference between revisions
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... |
No edit summary |
||
(5 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
== Cerință == | == Cerință == | ||
Se dau numerele naturale b n p. Determinați numărul format din ultimele p cifre ale lui | 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 == | ||
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 ⩽ b ⩽ 1000000000 | *1 ⩽ '''b''' ⩽ 1000000000 | ||
*1 ⩽ n ⩽ 2^31 | *1 ⩽ '''n''' ⩽ 2^31 | ||
*1 ⩽ p ⩽ 9 | *1 ⩽ '''p''' ⩽ 9 | ||
== Exemplul 1== | ==Exemplu== | ||
=== Exemplul 1=== | |||
; Intrare | ; Intrare | ||
: 2 | : 2 | ||
Line 17: | Line 19: | ||
: Datele introduse corespund restricțiilor impuse. | : Datele introduse corespund restricțiilor impuse. | ||
: 24 | : 24 | ||
=== Exemplul 2 === | |||
== Exemplul 2 == | |||
; Intrare | ; Intrare | ||
: 123456789 | : 123456789 | ||
Line 25: | Line 26: | ||
; Ieșire | ; Ieșire | ||
: Datele introduse corespund restricțiilor impuse. | : Datele introduse corespund restricțiilor impuse. | ||
: | : 949 | ||
< | ==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> |
Latest revision as of 08:41, 25 April 2023
Cerință[edit | edit source]
Se dau numerele naturale b n p. Determinați numărul format din ultimele p cifre ale lui .
Date de intrare[edit | edit source]
Programul citește de la tastatură numerele b n p.
Date de ieșire[edit | edit source]
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[edit | edit source]
- 1 ⩽ b ⩽ 1000000000
- 1 ⩽ n ⩽ 2^31
- 1 ⩽ p ⩽ 9
Exemplu[edit | edit source]
Exemplul 1[edit | edit source]
- Intrare
- 2
- 10
- 2
- Ieșire
- Datele introduse corespund restricțiilor impuse.
- 24
Exemplul 2[edit | edit source]
- Intrare
- 123456789
- 5
- 3
- Ieșire
- Datele introduse corespund restricțiilor impuse.
- 949
Rezolvare[edit | edit source]
Rezolvare vers. 1[edit | edit source]
<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>