forked from EndlessCheng/codeforces-go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathodt_bst.go
75 lines (67 loc) · 1.96 KB
/
odt_bst.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
package copypasta
// "Old Driver Tree"
// 一种可以动态合并与分裂的分块结构,在随机数据下有高效性能 O(nloglogn)
// https://oi-wiki.org/ds/odt/
// todo 随机数据下的复杂度证明 https://zhuanlan.zhihu.com/p/102786071
// https://codeforces.com/problemset/problem/558/E
// 代码 https://codeforces.com/problemset/submission/558/117163317
// https://codeforces.com/problemset/problem/915/E
// 代码 https://codeforces.com/problemset/submission/915/117158161
// https://codeforces.com/problemset/problem/817/F 数据水
// 代码 https://codeforces.com/contest/817/submission/118365591
// todo https://www.luogu.com.cn/problem/P5350
// https://www.luogu.com.cn/problem/P5586
// 使用时,为简化判断,可在初始时插入一段 [1,n] 区间(或 [0,2e9] 等)
type odtNode struct {
tpNode
l, r int
}
func (t *treap) put1(l, r int, val tpValueType) {}
func (t *treap) floor(int) (_ *odtNode) { return }
func (t *treap) next(int) (_ *odtNode) { return }
func (t *treap) split(mid int) {
if o := t.floor(mid); o.l < mid && mid <= o.r {
r, val := o.r, o.val
o.r = mid - 1
t.put1(mid, r, val)
}
}
func (t *treap) prepare(l, r int) {
t.split(l)
t.split(r + 1)
}
func (t *treap) merge(l, r int, value tpValueType) {
t.prepare(l, r)
// 保留 l,后面直接修改,从而代替删除+插入操作
for o := t.next(l); o != nil && o.l <= r; o = t.next(o.l) {
t.delete(tpKeyType(o.l))
}
o := t.floor(l)
o.r = r
o.val = value
}
// https://codeforces.com/problemset/problem/558/E
func (t *treap) sortBytes(l, r int, inc bool) {
t.prepare(l, r)
// 整段删除重建
cnt := [26]int{}
for o := t.floor(l); o != nil && o.l <= r; o = t.next(o.l) {
cnt[o.val] += o.r - o.l + 1
t.delete(tpKeyType(o.l))
}
if inc {
for i, c := range cnt {
if c > 0 {
t.put1(l, l+c-1, tpValueType(i))
l += c
}
}
} else {
for i, c := range cnt {
if c > 0 {
t.put1(r-c+1, r, tpValueType(i))
r -= c
}
}
}
}