1017 - Sum Pare Vec

From Bitnami MediaWiki

Cerința

Se consideră un șir cu n elemente, numere naturale. Folosind metoda Divide et Impera, determinați suma elementelor pare din acest șir.

Date de intrare

Programul citește de la tastatură numărul n, iar apoi cele n elemente ale șirului.

Date de ieșire

Programul va afișa pe ecran numărul S, reprezentând suma cerută.

Restricții și precizări

  • 1 ≤ n ≤ 1000
  • elementele șirului vor fi mai mici decât 1.000.000
  • se recomandă folosirea metodei Divide et Impera

Exemplul 1

Intrare

6
4 1 8 4 3 5 

Ieșire

16

Exemplul 2

Intrare

5
11111111111

Ieșire

Eroare: Elementul 11111111111 trebuie să fie între 1 și 1000000.

Rezolvare

<syntaxhighlight lang="python3" line="1"> def validate_input(n):

   if not (1 <= n <= 1000):
       print("Eroare: Numărul de elemente trebuie să fie între 1 și 1000.")
       exit()

def validate_element(element):

   if not (1 <= element <= 1000000):
       print(f"Eroare: Elementul {element} trebuie să fie între 1 și 1000000.")
       exit()

def sum_of_even_elements(arr, start, end):

   if start > end:
       return 0
   
   mid = (start + end) // 2
   left_sum = sum_of_even_elements(arr, start, mid - 1)
   right_sum = sum_of_even_elements(arr, mid + 1, end)
   current_sum = 0
   if arr[mid] % 2 == 0:
       current_sum = arr[mid]
   return left_sum + right_sum + current_sum

def main():

   n = int(input("Introduceți numărul de elemente: "))
   validate_input(n)
   arr = []
   for i in range(n):
       element = int(input(f"Introduceți elementul {i + 1}: "))
       validate_element(element)
       arr.append(element)
   result = sum_of_even_elements(arr, 0, n - 1)
   print(f"Suma elementelor pare din șir: {result}")

if __name__ == "__main__":

   main()

</syntaxhighlight>