Program n_15; var i: integer; x: real; begin writeln ('график тренировок'); i: =1; x: =10; repeat i: =i+1 x: =x+0.1*x; until x> =25; writeln ('начиная с ', i, '-го дня спортсмен будет пробегать 25 км') end. дополните программу возможностью определить длину пути, который пробежит спортсмен за все найденное выше время тренировок. указание: обозначьте переменную s, опишите ее, добавьте в тело цикла накопление суммы расстояний в эту переменную (строка вида: s: =s+что-то) – подумайте, в какое место тела цикла нужно поставить эту формулу, выведите на экран значение s, округлив его до двух знаков после запятой (s: 3: 2).
import sys
A = int(input())
B = int(input())
C = int(input())
D = int(input())
K = int(input())
def check(x, y):
if abs(x) > K or abs(y) > K:
return 0
y += A
if y >= K:
return A - (y - K)
x += B
if x >= K:
return A + B - (x - K)
y -= C
if y <= -K:
return A + B + C - (-y - K)
x -= D
if x <= -K:
return A + B + C + D - (-x - K)
return -1
if check(0, 0) != -1:
print(check(0, 0))
sys.exit(0)
x = B - D
y = A - C
left = 0
right = 10 ** 9
while right - left > 1:
mid = (left + right) // 2
if check(x * mid, y * mid) == -1:
left = mid
else:
right = mid
print(right * (A + B + C + D) + check(x * right, y * right))
Объяснение: