18130 繁忙的公路

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;
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值