POJ 3468 A Simple Problem with Integers(树状数组)


solution:区间更新区间查询的树状数组

#include <iostream>
using namespace std;

long long n,m;
long long a[100005] = {0};
long long sum1[100005];    //(D[1] + D[2] + ... + D[n])
long long sum2[100005];    //(1*D[1] + 2*D[2] + ... + n*D[n])

long long lowbit(long long x){
    return x & (-x);
}

void updata(long long i,long long k){
    long long x = i;    //因为x不变,所以得先保存i值
    while(i <= n){
        sum1[i] += k;
        sum2[i] += k * (x-1);
        i += lowbit(i);
    }
}

long long getsum(long long i){        //求前缀和
    long long res = 0, x = i;
    while(i > 0){
        res += x * sum1[i] - sum2[i];
        i -= lowbit(i);
    }
    return res;
}

int main(){
    cin >> n >> m;
    for(long long i = 1; i <= n; i++){
        cin>>a[i];
        updata(i,a[i] - a[i-1]);   //输入初值的时候,也相当于更新了值
    }
	while (m--)
	{
		char ch;
		long long a, b, c;
		cin >> ch >> a >> b;
		if (ch == 'Q'){
			cout << getsum(b) - getsum(a - 1) << endl;
		}else{
			cin >> c;
			updata(a, c);
			updata(b + 1, -c);
		}
		//[x,y]区间内加上k
	    //updata(x,k);    //A[x] - A[x-1]增加k
	    //updata(y+1,-k);        //A[y+1] - A[y]减少k

	    //求[x,y]区间和
	    //long long sum = getsum(y) - getsum(x-1);
	}
    return 0;
}
全部评论

相关推荐

身边有人上海、深圳&nbsp;6、7k&nbsp;都去了,真就带薪上班了。
小浪_coder:深圳除了一些计算机,UI设计,金融类等一些可以月薪过万的工作之外, 认识很多朋友做运营,营销,文员的工作, 月薪基本都在4-6K左右,还有大把人在干
点赞 评论 收藏
分享
半解316:内容充实,细节需要修改一下。 1,整体压缩为一页。所有内容顶格。 2,项目描述删除,直接写个人工作量 修改完之后还需要建议,可以私聊
点赞 评论 收藏
分享
见见123:简历没有啥问题,是这个社会有问题。因为你刚毕业,没有工作经历,现在企业都不要没有工作经历的。社会病了。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务