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

目录

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

问题分析

区间修改, 单点查询

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

因此可以求出原序列的差分序列 , 假设原序列是 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;
}
相关推荐
小O的算法实验室16 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
‎ദ്ദിᵔ.˛.ᵔ₎16 小时前
LIST 的相关知识
数据结构·list
M--Y17 小时前
Redis常用数据类型
数据结构·数据库·redis
郭涤生17 小时前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿17 小时前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz18 小时前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能18 小时前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****18 小时前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能18 小时前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能18 小时前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数