Description
在一条笔直的大道(单方向行车道)上,汽车川流不息。道路从起点到终点,等距离的标记了1到N, 即起点是1,然后分别是2、3、4.....,终点是N。每一个标记处,安装了智能探头,可以感知 在该点处车辆的增减数量。 一开始,整条道路上,没有车,然后,是不断接收到的智能探头发回的信息,格式如下: H 5 9 H表明收到的是智能探头的回传信息,5表示标记5处的车辆信息,9表示该处车辆增加了9辆。 同时,在某个时刻,需要查询在一段连续的道路上,共有多少辆车 查询格式如下: Q 3 10 Q表明收到的是查询,3是起点,10是终点(包括3和10两处) 要求编程实现正确处理上述信息处理和查询
输入格式
第一行一个整数N(1<=N<=1,000,000),表示标记范围是1到N 第二行一个整数M(1<=M<=100,000),表示探头信息(或查询)的总数量 此后M行,每行一个探头信息或查询请求
输出格式
每逢遇到查询的时候,输出查询范围内的有多少辆车,占一行,查询结果最大不超过2的63次方
输入样例
10 4 H 5 10 Q 1 10 H 6 20 Q 1 10
输出样例
10 30
提示
开始时,整条路上没有车辆
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
const int N=1e6+10;
int t[N];
int n,m;
ll lowbit(ll x){return x&-x;
}void add(ll x,ll k){for(ll i=x;i<=n;i+=lowbit(i)){t[i]+=k;}
}ll query(ll l,ll r){ll sum=0;for(ll i=l-1;i;i-=lowbit(i)){sum-=t[i];}for(ll i=r;i;i-=lowbit(i)){sum+=t[i];}return sum;
}
int main(){ll a,b;char ch;cin>>n>>m;for(int i=0;i<m;++i){cin>>ch>>a>>b;if(ch=='H'){add(a,b);//print();}else{ll s=query(a,b);cout<<s<<endl;}} return 0;
}