前缀和数组 差分数组

前缀和

一维:通过空间换时间适用于需要频繁查询某一段区间和的场景。

一维数组:

一维前缀和中的每一项:

,该前缀和中的每一项也就是数组中对应的前 i 项和。

一维前缀和数组的构造:

在输入原数组时同步构造前缀和数组可以改写为

cpp 复制代码
for(int i=1;i<=n;i++){
    scanf("%d",&arr[i]);
    crr[i]=crr[i-1]+arr[i];
  }

通常前缀和数组从下标为1开始的值默认为0

一维区间和查询:

查询原数组区间为 [ l , r ] 的元素的和:

二维:通过空间换时间适用于需要频繁查询某一个子矩阵中元素和的场景。

二维数组:

. . . . . . . . . . . . . . .

二维前缀和中的每一项:

,该前缀和中的每一项也就是数组中以这两个元素为对角线构成的矩形中元素和。

二维前缀和数组的构造:

也是在输入原数组时同步构造前缀和数组 根据二维数组一行一行地读入顺序可以改写为 ,运用这种类似于dp的想法就可以实现。

cpp 复制代码
for(int i=1;i<=n;i++){
    int sum=0;
    for(int j=1;j<=m;j++){
      scanf("%d",drr[i][j]);
      sum+=drr[i][j];
      crr[i][j]=crr[i-1][j]+sum;
    }
  }

和一维类似:行和列的都从1开始

二维子矩阵元素和查询:

查询以为对角线构成的子矩阵中元素和:

差分

一维:通过空间换时间适用于需要频繁进行区间数值的批量增减操作的场景。

一维数组:

一维差分数组中的每一项:

一维差分数组的构造:

边输入原数组边构造

cpp 复制代码
for(int i=1;i<=n;i++){
    scanf("%d",arr+i);
    diff[i]=arr[i]-arr[i-1];
  }

一维差分数组与原数组的推导关系: 由差分数组定义移项可得:

一维差分数组实现区间批量增减:

让区间 [ l , r ] 上的元素加x:让 加上x,让 减去x

这种区间批量增减操作是静态的无法一遍查询一边修改,需要统一在差分数组上修改完毕后再通过差分数组与原数组的关系还原回原数组,再实现查询。

二维:等待补充。。。。

相关推荐
我也要当昏君1 小时前
时间复杂度
算法·数学建模
业精于勤的牙2 小时前
浅谈:算法中的斐波那契数(六)
人工智能·算法
小孟的CDN2 小时前
使用pytorch进行batch_size分批训练,并使用adam+lbfgs算法——波士顿房价预测
pytorch·算法·batch·代码·adam+lbfgs
仰泳的熊猫2 小时前
1037 Magic Coupon
数据结构·c++·算法·pat考试
AI科技星2 小时前
质量定义方程的物理数学融合与求导验证
数据结构·人工智能·算法·机器学习·重构
小羊学伽瓦2 小时前
ThreadLocal
java·jvm·算法
程芯带你刷C语言简单算法题2 小时前
Day30~实现strcmp、strncmp、strchr、strpbrk
c语言·学习·算法·c
桓峰基因2 小时前
SCS 60.单细胞空间转录组空间聚类(SPATA2)
人工智能·算法·机器学习·数据挖掘·聚类
天赐学c语言2 小时前
12.17 - 合并两个有序数组 && include<> 和 include““ 的区别
c++·算法·leecode
摇摆的含羞草2 小时前
Java加解密相关的各种名词的含义,各种分类的算法及特点
java·开发语言·算法