本文整理汇总了C++中SegmentTree::sum方法的典型用法代码示例。如果您正苦于以下问题:C++ SegmentTree::sum方法的具体用法?C++ SegmentTree::sum怎么用?C++ SegmentTree::sum使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类SegmentTree
的用法示例。
在下文中一共展示了SegmentTree::sum方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: main
int main()
{
#ifdef LOCAL
// freopen("1008.in", "r", stdin);
// freopen("out.txt", "w", stdout);
#endif
int T;
scanf("%d", &T);
for(int ck=1; ck<=T; ck++)
{
scanf("%d%d", &N, &M);
for(int i=1; i<=N; i++) scanf("%d", &A[i]);
tree.len=N;
tree.build();
for(int i=1,opt,l,r,x; i<=M; i++)
{
scanf("%d%d%d", &opt, &l, &r);
if(opt==1) {scanf("%d", &x); tree.add(l,r,x);}
if(opt==2) {tree.rsqrt(l,r);}
if(opt==3) {printf("%lld\n", tree.sum(l,r));}
// PCUT;
}
}
return 0;
}
示例2: main
int main()
{
ifstream fin("sum.in");
ofstream fout("sum.out");
int n = 0, k = 0;
fin >> n >> k;
int *values = new int[n];
for (int i = 0; i < n; i++)
{
values[i] = 0;
}
SegmentTree rsq = SegmentTree(n, values);
for (int i = 0; i < k; i++)
{
char c;
int a, b;
fin >> c >> a >> b;
if (c == 'A')
rsq.update(a - 1, b);
else
fout << rsq.sum(a - 1, b - 1) << "\n";
}
return 0;
}