差分数组【自用笔记】【c++】

模拟差分数组寻找规律:原数组:shui,差分数组:chai , chai=shui-shui-1.

cpp 复制代码
//模拟差分数组寻找规律:
//下标 : 0 1  2   3   4  5
//       3 4  5   6   7  8          做差:下标为i的减去下标为(i-1)的 :3 1 1 1 1  1 
//【修改】将下标为2~下标为4的地方加5     
//变为: 3 4  10  11  12  8                                          :3 1 6 1 1 -4 
//   左下标:l,右下标:r,变化的值:k        cha[l]+=k;      cha[r+1]-=k;
// 差分数组推理:  cha[i]=shu[i]-shu[i-1];=>shu[i]=cha[i]+shu[i-1];

例题:【蓝桥杯OJ:3291】

题目链接:
1.区间更新 - 蓝桥云课https://www.lanqiao.cn/problems/3291/learning/?page=1&first_category_id=1&problem_id=3291

样例演示过程:【本题的下标是从1开始的】

cpp 复制代码
//下标:   1 2 3 4 5 6 7 8 9 10
        //0 0 0 0 0 0 0 0 0 0
        //1 1 1 1 1 0 0 0 0 0
        //1 2 2 2 2 1 0 0 0 0
        //1 2 3 3 3 2 1 0 0 0
        //1 2 3 4 4 3 2 1 1 0
        //1 2 3 4 5 4 3 2 2 1

可执行代码:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N=1e5+10;
int shu[N];
int cha[N];
int main()
{
int n=0,m=0;
while(cin>>n>>m){
for(int i=1;i<=n;i++){
   cin>>shu[i]; 
   cha[i]=shu[i]-shu[i-1];
}
for(int i=1;i<=m;i++){
  int x=0,y=0,z=0;cin>>x>>y>>z;
  cha[x]+=z;
  cha[y+1]-=z;
}
for(int i=1;i<=n;i++){
  shu[i]=cha[i]+shu[i-1];
  cout<<shu[i]<<" ";
}
cout<<endl;
memset(shu,0,sizeof(shu));
memset(cha,0,sizeof(cha));
}
  return 0;
}
相关推荐
地平线开发者4 小时前
J6B vio scenario sample
算法
BothSavage16 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn16 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽18 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
郝学胜_神的一滴18 小时前
CMake 034:生成器表达式:解耦构建时序、精简分支逻辑的终极利器
c++·cmake
先吃饱再说1 天前
判断回文字符串,从一行代码到双指针优化
算法
见过夏天1 天前
C++ 基础入门完全指南
c++
黄敬峰2 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法