0057 - N Suma
Sursa: [1]
Cerinţa
Să se scrie un program care să citească n numere întregi și să calculeze suma lor.
Date de intrare
Fișierul de intrare n_suma.in conține pe prima linie numărul n, iar pe următoarele linii n numere întregi.
Date de ieșire
Fișierul de ieșire relativ.out va conține pe prima linie numărul k, reprezentând numărul termenilor din şir care sunt minime relative, iar pe a doua linie maximul sumei elementelor dintr-o secvenţă cuprinsă între două minime relative consecutive din şir, inclusiv acestea.
Restricţii şi precizări
- 0 < n < 1000
- valoarea absolută a celor n numere citite va fi mai mică decât 1000.
Exemplul 1
- Intrare
- 5
- 1
- 2
- 3
- 4
- 5
- Ieșire
- 15
Exemplul 2
- Intrare
- 3
- 3
- 5
- 9
- 2
- 7
- Ieșire
- 17
Rezolvare
<syntaxhighlight lang="python" line>
- 1468
def validate_input(n, numbers):
if not 1 <= n <= 1000000: print("Input invalid: n trebuie să fie între 1 și 1.000.000") exit() if len(numbers) != n: print("Input invalid: numărul de numere nu corespunde valorii lui n") exit() for num in numbers: if not 1 <= num <= 1000000000: print("Input invalid: numerele trebuie să fie între 1 și 1.000.000.000") exit()
def main(input_file, output_file):
with open(input_file, 'r') as f_in, open(output_file, 'w') as f_out: n = int(f_in.readline().strip()) numbers = list(map(int, f_in.readlines())) validate_input(n, numbers) cnt, minim = 0, 1000000001 maxim, s = 0, 0 for x in numbers: if x <= minim: if s + x > maxim: maxim = s + x cnt += 1 minim = x s = x elif x > minim: s += x f_out.write(str(cnt) + '\n') f_out.write(str(maxim) + '\n')
main('relativ.in', 'relativ.out')
</syntaxhighlight>
Explicatie rezolvare
Acest program citeste un numar intreg n din fisierul n_suma.in si o lista de numere intregi numbers de lungime n, apoi calculeaza suma tuturor numerelor din lista si o scrie in fisierul n_suma.out.
Inainte de a efectua calculele, programul verifica daca datele de intrare sunt valide, folosind functia validate_input(n, numbers). Aceasta functie returneaza False daca n este negativ sau depaseste 1000 sau daca orice element din numbers are o valoare absoluta mai mare sau egala cu 1000. Daca datele de intrare nu sunt valide, programul scrie mesajul "Date de intrare invalide" in fisierul "n_suma.out" si se opreste prin instructiunea return.
Daca datele de intrare sunt valide, programul calculeaza suma elementelor din numbers cu functia sum() si scrie valoarea in fisierul n_suma.out cu ostr.write().