[题] 差分 #差分

题目

差分


题解

复制代码
将要加上某个数的区间第一个数加上要加的数,
区间末的后一个元素减去此元素
就可以使区间内的数都加上此元素而后面的数保持原样

代码

cpp 复制代码
#include<bits/stdc++.h>
#define MAXN 200005
using namespace std;
int n,m,a[MAXN],b[MAXN];
int main(){
    cin >> n >> m;
    //原数组a
    for(int i = 1; i <= n; i ++) 
		cin >> a[i];
	//差分数组b 
    int l, r, c;
    for(int i =1 ; i <= m; i ++){
        cin >> l >> r >> c;
        b[l] += c; 
		b[r + 1] -= c;
    }
    //求差分的前缀和,得到的b[i]就是a[i]最后要加上的数
    for(int i = 1; i <= n ;i ++) 
		b[i] += b[i - 1];
    for(int i = 1; i <= n; i ++) 
		cout << a[i] + b[i] << " ";
    return 0;
}
相关推荐
枫叶丹45 小时前
【Qt开发】Qt系统(三)->事件过滤器
java·c语言·开发语言·数据库·c++·qt
wjs20245 小时前
CSS Position(定位)
开发语言
亓才孓5 小时前
继承父类和接口,又冲突的变量名怎么解决
java·开发语言
池塘的蜗牛6 小时前
mmse-based-OFDM-signal-processing(2)
算法
superman超哥6 小时前
Rust API 设计的零成本抽象原则:性能与表达力的完美统一
开发语言·后端·rust·rust api·抽象原则·性能与表达力
Kris_LinSD6 小时前
算法小实验——分治算法快速排序问题实验(含报告)
c语言·算法
云栖梦泽6 小时前
Rust语言:系统级编程的新时代选择
开发语言
qq_406176146 小时前
什么是模块化
开发语言·前端·javascript·ajax·html5
Super小白&6 小时前
十大经典排序算法详解(附C语言实现+复杂度分析)
c语言·算法·排序算法
Eloudy6 小时前
Birkhoff 多胞形,双随机矩阵的几何世界
算法