基础数据结构应用-一个简单的整数问题

目录

题目-一个简单的整数问题

问题分析

区间修改, 单点查询

但是树状数组只能支持单点修改, 单点查询

因此可以求出原序列的差分序列 , 假设原序列是 a 1 , a 2 , a 3 , . . . , a n a_1, a_2, a_3, ..., a_n a1,a2,a3,...,an

求出差分序列
b 1 , b 2 , b 3 , . . . , b n b_1, b_2, b_3, ..., b_n b1,b2,b3,...,bn
b 1 = a 1 − a 0 b_1 = a_1 - a_0 b1=a1−a0, b 2 = a 2 − a 1 b_2 = a_2 - a_1 b2=a2−a1...

差分序列的前缀和 就是原来位置的值

如果对原序列的一个区间 [ L , R ] [L, R] [L,R]进行增加 d d d, 那么就是差分序列 b L + d b_{L} + d bL+d, b R + 1 − d b_{R+ 1} - d bR+1−d

算法步骤

  • 求出原序列的差分序列
  • 构建树状数组
  • 区间修改转化为差分序列的单点修改
  • 查询原序列的 x x x位置的值, 相当于求差分序列的前缀和, 也就是树状数组的操作

算法时间复杂度 O ( M log ⁡ N ) O(M \log N) O(MlogN)

代码实现

cpp 复制代码
#include <bits/stdc++.h>

using namespace std;

const int N = 1e5 + 10;

int n, m;
int a[N], b[N];
int tr[N];

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

void modify(int u, int val) {
    for (int i = u; i <= n; i += lowbit(i)) tr[i] += val;
}

int get(int u) {
    int ans = 0;
    for (int i = u; i; i -= lowbit(i)) ans += tr[i];
    return ans;
}

int main() {
    ios::sync_with_stdio(false);
    cin.tie(0);

    cin >> n >> m;
    for (int i = 1; i <= n; ++i) {
        cin >> a[i];
        b[i] = a[i] - a[i - 1];
    }
    
    for (int i = 1; i <= n; ++i) modify(i, b[i]);

    while (m--) {
        char c;
        cin >> c;
        if (c == 'C') {
            int l, r, val;
            cin >> l >> r >> val;
            modify(l, val);
            modify(r + 1, -val);
        }
        else {
            int x;
            cin >> x;
            cout << get(x) << '\n';
        }
    }

    return 0;
}
相关推荐
清铎1 小时前
leetcode_day12_滑动窗口_《绝境求生》
python·算法·leetcode·动态规划
linweidong1 小时前
嵌入式电机:如何在低速和高负载状态下保持FOC(Field-Oriented Control)算法的电流控制稳定?
stm32·单片机·算法
net3m332 小时前
单片机屏幕多级菜单系统之当前屏幕号+屏幕菜单当前深度 机制
c语言·c++·算法
mmz12072 小时前
二分查找(c++)
开发语言·c++·算法
Insight2 小时前
拒绝手动 Copy!一文吃透 PyTorch/NumPy 中的广播机制 (Broadcasting)
算法
CoovallyAIHub2 小时前
工业视觉检测:多模态大模型的诱惑
深度学习·算法·计算机视觉
Jayden_Ruan2 小时前
C++分解质因数
数据结构·c++·算法
bubiyoushang8883 小时前
MATLAB实现雷达恒虚警检测
数据结构·算法·matlab
wu_asia3 小时前
编程技巧:如何高效输出特定倍数数列
c语言·数据结构·算法
AlenTech3 小时前
207. 课程表 - 力扣(LeetCode)
算法·leetcode·职场和发展