Хочу решить задачу: https://www.e-olymp.com/ru/problems/3252. Но меня смущает что n слишком велико( n <= 10^9 + 7).
№ | Пользователь | Рейтинг |
---|---|---|
1 | tourist | 4009 |
2 | jiangly | 3823 |
3 | Benq | 3738 |
4 | Radewoosh | 3633 |
5 | jqdai0815 | 3620 |
6 | orzdevinwang | 3529 |
7 | ecnerwala | 3446 |
8 | Um_nik | 3396 |
9 | ksun48 | 3390 |
10 | gamegame | 3386 |
Страны | Города | Организации | Всё → |
№ | Пользователь | Вклад |
---|---|---|
1 | cry | 167 |
2 | Um_nik | 163 |
3 | maomao90 | 162 |
3 | atcoder_official | 162 |
5 | adamant | 159 |
6 | -is-this-fft- | 158 |
7 | awoo | 157 |
8 | TheScrasse | 154 |
9 | Dominater069 | 153 |
9 | nor | 153 |
Хочу решить задачу: https://www.e-olymp.com/ru/problems/3252. Но меня смущает что n слишком велико( n <= 10^9 + 7).
Название |
---|
Надо использовать динамическое дерево отрезков
ограничение по памяти 64мб. Думаешь пройдет?
Оно потому и динамическое, что ест мало :) Но конкретно в этой задаче проще использовать дерево фенвика, попросту заменив массив на map / unordered map
http://paste.ubuntu.com/24764544/ Вот такая реализация дает memory limit
Можно поменять на unordered и поставить при подсчете суммы проверку, что запрашиваемый элемент в дереве есть через count.
Или же написать декартово дерево или динамическое дерево отрезков (можно опять же через map :D)
Решил с помощью дерева отрезков на указателях(вершина добавляется только тогда, когда она нужна).
По личному опыту могу посоветовать писать его не на указателях, а на массиве (тот же принцип — создаём когда нужно, только теперь для каждой вершины будем хранить int l, r; — указатели на сыновей и глобальный cnt — счётчик вершин, создание вершины выглядит так: l = cnt++; или r = cnt++; и т.д.), т.к. жрёт меньше памяти и работает быстрее (или, как минимум, одно из двух)
Спасибо, учту.
А еще лучше все-таки писать с массивом, но на указателях, а не индексах.