Рустам Абдрашитов
Мыслитель
(9532)
1 месяц назад
1. **Сумма покраски**: Сначала вычисляем общую покраску, складывая все $$ a_i $$. Если сумма меньше $$ k $$, выводим -1.
2. **Оптимизация времени**:
- Егор берет первую банку, идет к первой доске, красит её.
- Затем, если нужно, возвращается за следующей банкой.
- Время рассчитывается как: время на движение + время на покраску.
Примерный алгоритм:
- Если $$ k = 5 $$ и банки имеют $$ a = [1, 3, 2] $$:
- Сумма = 6 (достаточно).
- Время = 4 (взять первую) + 2 (покрасить) + 2 (вернуться за второй) + 8 (покрасить оставшиеся) = 14 секунд.
Вывод: минимальное время для покраски всего забора – 14 секунд.
Изначально Егор стоит слева от забора (прямо перед телегой), при этом в его руке нет банки с краской. Егор пока что не окончил вуз, поэтому набор его навыков ограничен: Взять банку с краской. Если Егор стоит перед телегой, то он может взять в руку любую банку, в которой ещё осталась краска. Если у Егора уже была какая‑то банка в руке, то он возьмёт новую, а старую оставит у телеги. Это действие не занимает времени. Сдвинуться вправо. После этого Егор перейдёт к следующей доске. Если Егор стоял у телеги, то после этого перемещения он будет стоять перед первой доской. При этом Егор не может сдвинуться вправо, если он уже у находится у последней доски. Это действие занимает 1 секунду.
Сдвинуться влево. После этого Егор перейдёт к предыдущей доске. Если Егор стоит у первой доски, то после этого перемещения он будет стоять перед телегой. Конечно же, Егор не может сдвинуться влево, если он стоит перед телегой. Это действие занимает 1 секунду. Покрасить доску. Если Егор сейчас стоит перед непокрашенной доской и у него в руках есть банка с краской, то он может покрасить эту доску. Это действие занимает 1 секунду. Раньше Егор был пасечником, а потому ему не понаслышке известна фраза «Время —— деньги!». Соответственно, он хочет как можно быстрее покрасить весь забор. Вы ведь помните, что Егор не окончил вуз? Именно поэтому вам придётся посчитать, какое минимальное время потребуется на покраску всего забора. Обратите внимание на то, что Егор имеет право закончить покраску в любом месте забора и что ему не надо после этого возвращаться к телеге.
Формат входных данных
В первой строке дано целое число k (1≤k≤109) количество досок в заборе.
Во второй строке дано целое число n (1≤n≤2⋅105) количество банок в телеге.
В следующих nn строках даны целые числа ai (1≤ai≤109) число досок, которые можно покрасить краской из банки с номером i.
Формат выходных данных
Выведите минимальное количество секунд, которое потребуется Егору для покраски всего забора. Если Егору не хватит краски для выполнения его задания, то выведите «−1» (без кавычек).
Замечание
Рассмотрим первый пример. В заборе всего пять досок. Чтобы покрасить его как можно быстрее, Егору нужно сначала взять третью банку, потом покрасить первые две доски на это у него уйдёт 4 секунды. Затем он должен вернуться назад и взять банку, которой хватит на три доски, на это ещё 2 секунды. Затем надо докрасить забор на это он потратит ещё 8 секунд, первые две из которых будет идти рядом с уже покрашенными досками. Итого потребуется 4+2+8=14 секунд. Во втором примере у Егора есть возможность покрасить только одну доску, но этого не хватит на покраску всего забора.
Ввод
5
3
1
3
2
Вывод
14