差分数组 ----- 从零开始的数据结构

一.前言:

我们都知道 "前缀和"数组 适用于 "原数组 " 不被修改的场景下,频繁查询某一个区间的累加和---查询时候时间复杂度是 O(1)

本文要提及的 "差分数组" 则是 适用于频繁对原数组的某一个 "区间" 的元素进行增减时-----修改数据的时候时间复杂度就是O(1)

我们会发现这两种数组都运用了空间换时间的思想,降低在某项功能的时间复杂度

简单介绍了两者的异同之后,我们步入今天的正题,差分数组!

二.差分数组

1.储存内容:

差分数组储存的内容是 "原数组" 的第 i 项 与 第 i - 1 项的差值(第一个元素特殊处理)

假设原数组是nums , 差分数组是 diff

• diff【0】= nums0

• diff【i】 = nums【i】 - nums【i - 1】

那么我们就可以顺利成章的写出构造"差分数组"的代码了

2.构造:

cpp 复制代码
class difference{
   private:
       vector<int> diff;
   public:
       difference(vector<int>& nums){
           diff = vector<int>(nums.size(),0);//构造了一个nums大小的差分数组
           diff[0] = nums[0];
           for (int i = 1; i < nums.size(); i++){
             diff[i] = nums[i] - nums[i-1];
           }
       }// nums是原数组

3.原数组区间增删的更改------核心功能:

假设我们要给原数组 i 到 j 区间都增加 val

我们知道差分数组的每一个下标值都代表的是 原数组 i 下标和 i -1 下标的"差值"

那么 i 位置的 差值 相比 i -1 是不是 会增加 "val"

i 到 j 区间因为都增加,那么差值不变,我们不动它

j + 1 相比于 j 下标 是不是就小了 "val"

那么代码可出:

cpp 复制代码
  void increment(int i , int j , int val){
            diff[i] += val;
            if (j + 1 < diff.size()){
                diff[j+1] -= val;
            }
       }

4. 返回差分数组

cpp 复制代码
  vector<int> result(){
            vector<int> res(diff.size());
            res[0] = diff[0];
            for (int i = 1; i < diff.size(); i++){
                res[i] = res[i-1] + diff[i];
            }
            return res;
       }

三.结语:

希望本文对你有所帮助

喜欢的话,可以点一个免费的赞和收藏

相关推荐
CSharp精选营2 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
刘马想放假5 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠6 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦13 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠14 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾14 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres82114 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q14 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒14 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记14 天前
单项不带头不循环链表
数据结构·链表