AcWing 243. 一个简单的整数问题2(树状数组实现区间修改+区间查询)

简介: 笔记

AcWing243. 一个简单的整数问题2(树状数组实现区间修改+区间查询)


10.png


给定一个长度为N的数列A,以及M条指令,每条指令可能是以下两种之一:


1、“C l r d”,表示把 A[l],A[l+1],…,A[r] 都加上 d。


2、“Q l r”,表示询问 数列中第 l~r 个数的和。


对于每个询问,输出一个整数表示答案。


输入格式

第一行两个整数N,M。


第二行N个整数A[i]。


接下来M行表示M条指令,每条指令的格式如题目描述所示。


输出格式

对于每个询问,输出一个整数表示答案。


每个答案占一行。


数据范围11.png


代码

#include <iostream>
using namespace std;
typedef long long LL;
const int N = 100010;
int n , m;
int a[N];
LL tr1[N] , tr2[N];
int lowbit(int x)
{
    return x & -x;
}
void add(LL tr[] , int x , LL c)
{
    for(int i = x ; i <= n ; i += lowbit(i))    tr[i] += c;
}
LL sum(LL tr[] , int x)
{
    LL res = 0;
    for(int i = x ; i ; i -= lowbit(i))   res += tr[i];
    return res;
}
LL prefix_sum(int x)
{
    return sum(tr1 , x) * (x + 1) - sum(tr2 , x);
}
int main()
{
    scanf("%d%d" , &n , &m);
    for(int i = 1; i <= n ; i++)    scanf("%d", &a[i]);
    for(int i = 1 ; i <= n ; i++)
    {
        int b = a[i] - a[i - 1];
        add(tr1 , i , b);
        add(tr2 , i , (LL)b * i);
    }
    while(m--)
    {
        int l , r , d;
        char op[2];
        scanf("%s%d%d" , op , &l , &r);
        if(*op == 'Q')
            cout << prefix_sum(r) - prefix_sum(l - 1) << endl;
        else
        {   
            scanf("%d" , &d);
            add(tr1 , l , d) , add(tr1 , r + 1 , -d);
            add(tr2 , l , l * d) , add(tr2 , r + 1 , (r + 1) * (- d));
        }
    }
        return 0;
}


目录
相关文章
|
算法 测试技术 C++
C++二分算法习题:判断是否是完全平方数[容易]和排列箱子[容易]
C++二分算法习题:判断是否是完全平方数[容易]和排列箱子[容易]
线段树的区间修改
线段树的区间修改
51 0
|
3月前
|
人工智能 算法 C语言
详解树状数组(C/C++)
详解树状数组(C/C++)
|
6月前
|
算法
【算法】二分查找(整数二分和浮点数二分)
算法学习——二分查找(整数二分和浮点数二分)
49 0
【算法】二分查找(整数二分和浮点数二分)
|
算法
数星星(树状数组模板题)
数星星(树状数组模板题)
71 0
|
算法
leetcode-每日一题873. 最长的斐波那契子序列的长度(哈希和二分)
题目要求斐波那契数列长度要大于等于3,就等于说要确定 x[1] 和 x[2]来确定x[3]…x[n]之和的数列,所以我们用两层for循环来枚举x[1] 和 x[2] ,因为斐波那契数列满足 x[i] = x[i - 1] + x[i - 2], 所以x[3] = x[1] + x[2] x[4] = x[3] + x[2]…,我们只需要三个变量来不断变换, 每次从 arr 中找前两个数,然后查看后续在符合斐波那契的数在arr中是否存在
110 0
leetcode-每日一题873. 最长的斐波那契子序列的长度(哈希和二分)
|
人工智能 索引
树状数组总结
能够解决数据压缩里的累积频率的计算问题,现多用于高效计算数列的前缀和、区间和。
126 0
树状数组总结
力扣刷题记录——326.3的幂、338. 比特位计数、342. 4的幂、350. 两个数组的交集 II
力扣刷题记录——326.3的幂、338. 比特位计数、342. 4的幂、350. 两个数组的交集 II
力扣刷题记录——326.3的幂、338. 比特位计数、342. 4的幂、350. 两个数组的交集 II