1298 - Suma 34
Cerința[edit | edit source]
Fiind dat un număr natural n
, se cere să se calculeze suma cifrelor numărului care reprezintă numărul de numere de n
cifre formate cu cifrele 3
şi 4
.
Date de intrare[edit | edit source]
Programul citește de la tastatură numărul n
.
Date de ieșire[edit | edit source]
Pe ecran se va afișa mesajul: "Datele de intrare corespund restricțiilor impuse."
Pe următoarea linie se va afișa numărul S
, reprezentând suma cerută.
În cazul în care datele introduse de la tastatură nu îndeplinesc cerințele enunțate, pe ecran se va afișa mesajul "Datele de intrare nu corespund restricțiilor impuse."
Restricții și precizări[edit | edit source]
1 ≤ n ≤ 100.000
Exemplu 1[edit | edit source]
- Intrare
- 4
- Ieșire
- Datele de intrare corespund restricțiilor impuse.
- 7
Explicație[edit | edit source]
Numerele de 4
cifre formate cu cifrele 3
şi 4
sunt 3333
, 3334
, 3343
, 3433
, 4333
, 3344
, 3434
, 4334
, 4343
, 4433
, 3443
, 3444
, 4344
, 4434
, 4443
, 4444
. Deci sunt 16
numere, iar suma cifrelor este S=7
.
Exemplu 2[edit | edit source]
- Intrare
- -5
- Ieșire
- Datele de intrare nu corespund restricțiilor impuse.
Rezolvare[edit | edit source]
<syntaxhighlight lang="python" line="1">
- 1298 - Suma34
def conditii(n):
return 1 <= n <= 100_000
def suma34(n):
# Numărul fiind alcătuit din n cifre, fiecare cifră din acel număr poate fi 3 sau 4, adică avem doar 2 posibilități. # Multiplicând numărul de posibilități (2) de n ori, obținem 2^n. numere_posibile = 2**n # Însumăm cifrele din numărul obținut. suma_cifre = sum([int(cifra) for cifra in str(numere_posibile)]) print(suma_cifre)
if __name__ == "__main__":
n = int(input())
if not conditii(n): print("Datele de intrare nu corespund restricțiilor impuse.") else: print("Datele de intrare corespund restricțiilor impuse.") suma34(n)
</syntaxhighlight>