-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathfenwick_tree.cpp
More file actions
47 lines (38 loc) · 771 Bytes
/
fenwick_tree.cpp
File metadata and controls
47 lines (38 loc) · 771 Bytes
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
/*
In the name of ALLAH
Author : Raashid Anwar
*/
#include <bits/stdc++.h>
using namespace std;
#define int int64_t
const int M1 = 998244353;
const int M2 = 1000000007;
mt19937 rng((uint64_t)chrono::steady_clock::now().time_since_epoch().count());
class fenwick_tree {
vector <int> tree;
int n;
public :
fenwick_tree(int _n) : n(_n) {
tree.resize(n + 1, 0);
}
void upd(int i, int x) {
for (; i <= n; i += (i & -i))
tree[i] += x;
}
int get(int i) {
int sum = 0;
for (; i; i -= (i & -i))
sum += tree[i];
return sum;
}
void clear() {
tree.resize(n + 1, 0);
}
};
void solve() {
}
int32_t main() {
ios_base::sync_with_stdio(0);
cin.tie(0);
solve();
}