3246 - Echilibrat ab

From Bitnami MediaWiki
Revision as of 12:47, 20 May 2023 by Pop Giulia (talk | contribs)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Sursa: [1]

Cerința

Se dau două numere naturale a și b. Calculați suma numerelor echilibrate din intervalul [a,b]. Un număr este echilibrat dacă are număr par de cifre si are numărul de cifre pare egal cu numărul de cifre impare. De exemplu 3427 este echilibrat, iar 2333 nu este.

Date de intrare

Programul citește de la tastatură numerele a și b.

Date de ieșire

Programul va afișa pe ecran numărul s, reprezentând suma numerelor echilibrate din intervalul [a,b].

Restricții și precizări

1 ≤ a ≤ b ≤ 1.000.000

Exemplu:

Intrare

56 71 Ieșire

509

Explicație

În intervalul [56,71] numerele echilibrate sunt 56, 58, 61, 63, 65, 67, 69, 70, iar suma lor este 509.

Încărcare soluție

<syntaxhighlight lang="python" line> def is_balanced(n):

   digits = [int(d) for d in str(n)]
   even_count = sum(d % 2 == 0 for d in digits)
   odd_count = len(digits) - even_count
   return len(digits) % 2 == 0 and even_count == odd_count

a, b = map(int, input().split())

sum_balanced = 0 for i in range(a, b+1):

   if is_balanced(i):
       sum_balanced += i

print(sum_balanced) </syntaxhighlight>