Андрей едет из пункта в пункт
на автомобиле. Расстояние между этими пунктами равно
километров. Известно, что с полным баком автомобиль способен проехать
километров. Дана карта, на которой отмечены координаты бензоколонок, относительно пункта
. Определите минимальное число заправок, которые придется сделать Андрею чтобы успешно достичь пункта
. Известно, что при выезде из пункта
бак был полон.
Входные данные
В первой строке вводятся числа и
(натуральные, не превосходят
). В следующей строке вводится количество бензоколонок
, потом следует
натуральных чисел, не превосходящих
— расстояния от пункта
до каждой заправки. Заправки упорядочены по удаленности от пункта
.
Выходные данные
Если при данных условиях пункта достичь невозможно, то вывести число
. Если решение существует, то вывести минимальное количество остановок на дозаправку, которое нужно, чтобы достичь пункта
.
f = open("input.txt")
n, k = [int(i) for i in f.readline().split()]
s = int(f.readline())
# список координат каждой заправки
d = [int(i) for i in f.readlines()]
# добавляем в список координат координату точки B
# это нужно для того, чтобы мы могли проверить,
# можно ли доехать с последней заправки до точки B без дозаправки или нет
d.append(n)
current_fuel = k # текущая наполненность бака
current_dist = 0 # пройденное расстояние
ans = 0 # ответ
possible = True # флаг, указывающий то, смогли ли мы доехать до пункта B
coords = []
for i in range(s+1):
# проверка того, что мы не сможем проехать до следующей
# заправки и нам нужно заправиться
if d[i] - current_dist > current_fuel:
# проверка того, что мы можем заправиться (в пункте A заправок нет)
# и проверка того, что мы после заправки сможем доехать до следующей заправки
if current_dist != 0 and k >= d[i] - current_dist:
current_fuel = k - (d[i] - current_dist)
ans += 1
coords.append(current_dist)
else:
possible = False
break
# если мы смогли доехать до следующей заправки без дозаправки,
# то необходимо уменьшить кол-во топлива в баке
else:
current_fuel -= (d[i] - current_dist)
current_dist = d[i]
if possible:
print(ans)
else:
print(-1)