Statement is not available in English language
G. Прибыль пиратов
ограничение по времени на тест
2 секунды
ограничение по памяти на тест
1024 мегабайта
ввод
стандартный ввод
вывод
стандартный вывод

Команда пиратов уже целый год вместе, и за это время они успели заработать много денег и много штрафов. По итогу года было решено разделить награбленное между командой. По старым пиратским обычаям нельзя просто так разделить поровну, этот вопрос касается и чести пирата. Для решения этого вопроса они открыли древний кодекс, который описывал, как делить в таком случае.

Нулевое правило кодекса гласило: «Награда и штрафы неделимы». Иными словами, итоговая сумма с $$$i$$$-го дела может достаться только одному пирату. При этом нельзя, чтобы сумма не досталась никому.

Первое правило кодекса гласило : «Каждый пират не может уйти в долгах или с ничем». То есть каждый пират суммарно получит положительную сумму монет.

Второе правило кодекса гласило: «Раздел должен быть непрерывным, как путь корабля». То есть дела нельзя разрывать или переставлять – каждый пират получает свою долю только из последовательных дел, как они шли в хронике года.

Третье правило кодекса гласило: «Младшим надо уступать». Это означало, что в начале самый младший выберет первые $$$s_1$$$ дел, затем второй по старшинству выберет следующие $$$s_2$$$ дел и так далее.

Четвертое правило кодекса гласило: «Старших надо уважать». Это означало, что если старший пират получил свою долю, то младший не может получить больше, иначе это будет ударом по репутации. Таким образом, заработанные суммы должны идти в порядке неубывания.

Пятое правило кодекса гласило: «Подумай о ближнем». Для пиратов это правило значило, что как можно больше пиратов должно уйти с деньгами, и они все преследовали эту цель.

Теперь им осталось понять, какое максимальное количество пиратов заработали в этом году. Помогите им с этой задачей.

Входные данные

В первой строке входных данных дано число $$$n$$$ — суммарное количество кладов и штрафов $$$(1 \le n \le 10^5)$$$.

Во второй строке дан массив целых чисел $$$a_1, a_2, \ldots, a_n$$$, где значение $$$a_i$$$ означает, что получили пираты с $$$i$$$-го дела. Если $$$a_i \ge 0$$$, то они заработали $$$a_i$$$ монет, иначе они получили штраф $$$-a_i$$$ монет.

Гарантируется, что $$$a_1 + a_2 + \ldots + a_n \gt 0$$$ и $$$|a_1| + |a_2| + \ldots + |a_n| \le 10^5$$$.

Выходные данные

Выведите, какому максимальному количеству пиратов можно выдать награду.

Система оценки

Тесты в этой задаче разбиты на 5 групп. Баллы за группу начисляются при прохождении всех тестов этой и всех необходимых групп. Примеры из условия не оцениваются.

ПодзадачаБаллыДоп. ограниченияНеобх. подзадачи
114$$$n \le 15$$$ 
220$$$n \le 10^3$$$1
318$$$0lt; a_1 \le a_2 \ldots \le a_n$$$ 
419$$$|a_1| + |a_2| + \ldots + |a_n| \le 100$$$ 
529$$$n \le 10^5$$$1–4
Примеры
Входные данные
3
1 2 3
Выходные данные
3
Входные данные
5
7 -5 3 -1 4
Выходные данные
3
Примечание

Во втором примере пираты могут получить (7 - 5), (3 - 1), 4