Дано число — количество мусорок, расположенных по кругу, затем
чисел — количество фантиков во всех этих мусорках, требуется найти количество фантиков, которое соберёт Максим за половину круга для всех его начальных позиций. Вывести все эти числа от
до
f = open("4.txt")
n = int(f.readline())
a = [int(f.readline()) for i in range(n)]
s = [0] * n
s[0] = sum(a[:n // 2])
for i in range(1, n):
s[i] = s[i - 1] - a[i - 1] + a[(i + n // 2 - 1) % n]
print(*s)
Ответ: 747 1082 1439 1507 1172 815