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

目录

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

问题分析

区间修改, 单点查询

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

因此可以求出原序列的差分序列 , 假设原序列是 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 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术2 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六5 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术6 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize7 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考20 小时前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营1 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
美团技术团队1 天前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
To_OC2 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC2 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode