#B215. 树状数组模板-单点修改区间查询

树状数组模板-单点修改区间查询

题目描述

给定数列a[1],a[2],…,a[n],你需要依次进行q个操作,操作有两类:

  • 1 i x:给定i,x,将a[i]加上x;
  • 0 l r:给定l,r,求a[l]+a[l+1]+⋯+a[r]的值。

输入格式

第一行包含2个正整数n,q,表示数列长度和询问个数。保证1≤n,q≤106{10}^6

第二行n个整数a[1],a[2],…,a[n],表示初始数列。保证∣a[i]∣≤106{10}^6

接下来q行,每行一个操作,为以下两种之一:

1 i x:给定i,x,将a[i]加上x;

0 l r:给定l,r,求a[l]+a[l+1]+⋯+a[r]的值。保证1≤l≤r≤n, ∣x∣≤106{10}^6

输出格式

对于每个0 l r操作输出一行,每行有一个整数,表示所求的结果。

3 2
1 2 3
1 2 0
0 1 3
6