Всем привет.
Можете ли вы подсказать как написать дерево отрезков с запросами видов:
l r x умножить все числа в отрезке с l по r на х
l r x прибавить ко всем числам в отрезке с l по r х
? р вывести элемент на позиции р
Заранее спасибо.
№ | Пользователь | Рейтинг |
---|---|---|
1 | jiangly | 3898 |
2 | tourist | 3840 |
3 | orzdevinwang | 3706 |
4 | ksun48 | 3691 |
5 | jqdai0815 | 3682 |
6 | ecnerwala | 3525 |
7 | gamegame | 3477 |
8 | Benq | 3468 |
9 | Ormlis | 3381 |
10 | maroonrk | 3379 |
Страны | Города | Организации | Всё → |
№ | Пользователь | Вклад |
---|---|---|
1 | cry | 168 |
2 | -is-this-fft- | 165 |
3 | Dominater069 | 161 |
4 | Um_nik | 159 |
4 | atcoder_official | 159 |
6 | djm03178 | 157 |
7 | adamant | 153 |
8 | luogu_official | 151 |
9 | awoo | 149 |
10 | TheScrasse | 146 |
Всем привет.
Можете ли вы подсказать как написать дерево отрезков с запросами видов:
l r x умножить все числа в отрезке с l по r на х
l r x прибавить ко всем числам в отрезке с l по r х
? р вывести элемент на позиции р
Заранее спасибо.
Название |
---|
Дерево отрозков: обновление на отрезке
Спасибо, кэп. К счастью я знаю о существование этого сайта. Хотелось бы узнать как одновременно умножать и плюсовать с помощью проталкивание!!!
Ну тогда почитай, там хорошие объяснения
Можно и без проталкивания. В каждой вершине будем хранить toAdd, toMult. Когда проходим вершину будем ответ умножать на toMult/добавлять toAdd. Будем ходить снизу вверх.
Имеешь ввиду запускать update с каждого листа???
Нет, делать Update с верху, но выводить ответ снизу.
не понял
Два push(), для умножения и для прибавления! А можно ссылку на задачу?
А как узнать что делать раньше, умножение или прибавление?
Республиканская-2013(Казахстан) задача F.
Модификация должна хранится в виде двух чисел: mul — на что умножить число, и add — что к нему прибавить. Если нужно в "модификацию" добавить умножение на x, то
mul *= x, add *= x
, если добавить x тоadd += x
; И дерево отрезков с проталкиванием.Понятно,спасибо.