[题] 差分 #差分

题目

差分


题解

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

代码

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;
}
相关推荐
ybzj.13 分钟前
2025年第十六届蓝桥杯省赛C/C++大学B组 个人题解
c++
LJianK113 分钟前
Java中的类、普通类,抽象类,接口的区别
java·开发语言
花月C13 分钟前
线性动态规划(Linear DP)
算法·动态规划·代理模式
Dev7z14 分钟前
基于MATLAB的5G物理层文本传输系统仿真与性能分析
开发语言·5g·matlab
小智社群14 分钟前
贝壳获取小区的名称
开发语言·前端·javascript
lsx20240625 分钟前
Python3 OS模块详解
开发语言
量子炒饭大师38 分钟前
【C++ 11】Cyber骇客 最后的一片净土 ——【C++11的 简单介绍 + 发展历史】历史唯物主义者带你理顺C++发展的由来
c++·dubbo·c++11
LiLiYuan.40 分钟前
【Java线程 vs 虚拟机线程】
java·开发语言
hetao173383742 分钟前
2025-03-24~04-06 hetao1733837 的刷题记录
c++·算法
_深海凉_1 小时前
LeetCode热题100-环形链表
算法·leetcode·链表