/
hld.test.cpp
53 lines (50 loc) · 1.54 KB
/
hld.test.cpp
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
#define PROBLEM "http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=GRL_5_D"
#include <cstdio>
#include <vector>
#include <functional>
using namespace std;
using ll = long long int;
#define call_from_test
#include "../../../graph/graph_020_HLDecomposition.cpp"
#include "../../../structure/strc_009_abst_lazy_segtree.cpp"
#undef call_from_test
int main() {
int N; scanf("%d", &N);
HLD hld(N);
for(int i=0; i<N; i++) {
int K; scanf("%d", &K);
for(int j=0; j<K; j++) {
int v; scanf("%d", &v);
hld.add_edge(i, v);
}
}
hld.build();
LazySegmentTree<ll, ll> seg(N, 0, 0,
[](ll a, ll b) { return a + b; },
[](ll a, ll b) { return a + b; },
[](ll a, ll b) { return a + b; },
[](ll a, int x) { return a * x; });
int Q; scanf("%d", &Q);
while(Q--) {
int t; scanf("%d", &t);
if(t == 0) {
int v, w; scanf("%d%d", &v, &w);
int u = hld.par[v];
hld.apply_edges(u, v, [&](int l, int r) {
seg.update(l, r, w);
});
}
if(t == 1) {
int u; scanf("%d", &u);
auto f = [&](int l, int r) {
return seg.query(l, r);
};
auto m = [&](ll v0, ll v1) {
return v0 + v1;
};
ll ans = hld.query_edges(0, u, 0, f, m);
printf("%lld\n", ans);
}
}
return 0;
}