差分(一维)

这篇具有很好参考价值的文章主要介绍了差分(一维)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、算法描述

本篇文章介绍前缀和的逆运算,差分。

什么是差分?

  • 差分是前缀和的逆运算,比如 \(a[n]\) 是原数组,\(s[n]\)\(a[n]\) 的前缀和数组,那么对于 \(s[n]\) 来说,\(a[n]\) 就是 \(s[n]\) 的差分数组。

  • 假设原数组为 \(a[n]\)\(b[n]\) 为差分数组,那么他们之间的关系为:b[1] = a[1]b[2] = a[2] - a[1]b[3] = a[3] - a[2]

差分有什么作用?

  • 预处理出来前缀和可以在 \(O(1)\) 的时间复杂度内求得区间 \([l, r]\) 的和。那么差分有什么作用呢?

  • 如果我们要让 \([l, r]\) 区间内的数都加上 \(c\) ,如果按照遍历的方式来操作那么时间复杂度会达到 \(O(n)\)

  • 但是我们知道前缀和数组 \(a[n]\) 是由原数组 \(b[n]\) 求得的,所以我们可以操作 \(b[n]\) ,进而改变 \(a[n]\) ,就变得简单多了。

  • 那么如何操作 \(b[n]\) 才能使得 \(a[n]\)\([l, r]\) 区间内都加上 \(c\) 呢?显然如果b[l] += c,那么对于 \(a[n]\) 来说 \(l\) 后面的所有数都会加上 \(c\) ,但是我们只需要 \([l, r]\) 区间内的数加上 \(c\) ,所以还需要b[r + 1] -= c;,这样就能达到我们想要的效果了。

如何得到差分?

  • 给定一个原数组 \(a[n]\) ,如何求得差分数组 \(b[n]\) 呢?

  • 其实很简单,由于 \(b[n]\) 刚开始都是 \(0\) ,所以插入一遍即可,insert(i, i, a[i])

  • 因为由 \(b\) 得到的前缀和此时都是 \(0\) ,每插入一次就会让得到的前缀和变成 \(a[i]\) ,插入一遍后,通过 \(b\) 求得的前缀和就是 \(a\) ,所以此时 \(b\) 就是 \(a\) 的差分。

  • 注意insert(i, i, a[i]) 是在操作 \(b\) 数组不是 \(a\) 数组,通过 \(b\) 求一遍前缀和才能得到 \(a\)数组。

二、题目描述

输入一个长度为 \(n\) 的整数序列。

接下来输入 \(m\) 个操作,每个操作包含三个整数 \(l, r, c\) 表示将序列中 \([l, r]\) 之间的每个数加上 \(c\)

请你输出进行完所有操作后的序列。

输入格式

第一行包含两个整数 \(n\)\(m\)

第二行包含 \(n\) 个整数,表示整数序列。

接下来 \(m\) 行,每行包含三个整数 \(l, r, c\),表示一个操作。

输出格式

共一行,包含 \(n\) 个整数,表示最终序列。

数据范围

\(1≤n,m≤100000,\)
\(1≤l≤r≤n,\)
\(−1000≤c≤1000,\)
\(−1000≤整数序列中元素的值≤1000\)文章来源地址https://www.toymoban.com/news/detail-711387.html

输入样例:

6 3
1 2 2 1 2 1
1 3 1
3 5 1
1 6 1 

输出样例:

3 4 5 3 4 2 

三、题目来源

AcWing算法基础课-797.差分

四、源代码

#include <iostream>

using namespace std;

const int N = 100010;

int n, m;
int a[N], b[N];

void insert(int l, int r, int c)
{
    b[l] += c;
    b[r + 1] -= c;
}

int main()
{
    cin >> n >> m;
    
    for (int i = 1; i <= n; ++i)    cin >> a[i];
    for (int i = 1; i <= n; ++i)    insert(i, i, a[i]);
    
    while (m -- )
    {
        int l, r, c;
        cin >> l >> r >> c;
        
        insert(l, r, c);
    }
    
    for (int i = 1; i <= n; ++i)    a[i] = a[i - 1] + b[i];
    for (int i = 1; i <= n; ++i)    cout << a[i] << ' ';
    
    return 0;
}

到了这里,关于差分(一维)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【算法】—前缀和与差分详解

     前缀和指一个数组的某下标之前的所有数组元素的和( 即数列的前n项求和 ),前缀和是一种重要的 预处理 ,能够降低算法的时间复杂度,可以快速地求出某一段的和,对于处理区间之间的问题是往往十分高效 相比较其他算法而言, 前缀和更像是一种解题的技巧,一种优

    2024年02月04日
    浏览(52)
  • 【算法基础2】前缀和与差分

    前缀和是某数列的前n项数的和,而差分则可以看做是前缀和的逆运算。前缀和与差分比起是一种算法,更像是一种解决问题的思路,通过构造一个特殊的数组,就可以让我们将某些复杂的问题简化。 (1)一维前缀和 已知一个数列a[n],用S[n]来表示这个数列的前n项和数列。

    2024年04月14日
    浏览(41)
  • 【OI学习笔记】基础算法-前缀和与差分算法

    板块:基础算法、线性优化 难度:较易 前置知识:C++基础语法 在一维空间中,对于一个数据总量为 n n n 的数组 a a a ,有数据 a [ 1 ] , a [ 2 ] , a [ 3 ] , . . . , a [ n − 1 ] , a [ n ] a[1],a[2],a[3],...,a[n-1],a[n] a [ 1 ] , a [ 2 ] , a [ 3 ] , ... , a [ n − 1 ] , a [ n ] ,定义一个数组 s u m sum s u m ,

    2024年02月08日
    浏览(48)
  • C++基础算法前缀和和差分篇

    📟作者主页:慢热的陕西人 🌴专栏链接:C++算法 📣欢迎各位大佬👍点赞🔥关注🚓收藏,🍉留言 主要讲解了前缀和和差分算法 Ⅵ .Ⅰ前缀和 ① 一维前缀和 : ​ 就是构建一个新的数组 s ,用来存储另一个数组的和前 i 个数组元素的和。用公式表达就是: S [ i ] = a [ 0 ]

    2024年02月16日
    浏览(50)
  • 【有营养的算法笔记】基础算法 —— 推导证明前缀和与差分

    👑作者主页:@安 度 因 🏠学习社区:StackFrame 📖专栏链接:有营养的算法笔记 如果无聊的话,就来逛逛 我的博客栈 吧! 🌹 Hello,小伙伴们,好几天没有更新了,今天更了一篇比较“硬核的文章”。 主要内容为前缀和与差分算法的推导证明和代码实现。这篇文章博主还是画

    2024年01月21日
    浏览(46)
  • 洛谷题单--算法[2-1] 前缀和、差分与离散化

    目录 0.铺垫学习:p1115最大子段和--前缀和+贪心+DP 1.p1719最大加权矩形--前缀和+贪心+DP+矩阵压缩 原题链接: P1115 最大子段和 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 原题: 题目描述 给出一个长度为 n 的序列 a,选出其中连续且非空的一段使得这段和最大。 输入格式 第

    2024年02月22日
    浏览(37)
  • 一文带你深入了解算法笔记中的前缀与差分(附源码)

    📖作者介绍:22级树莓人(计算机专业),热爱编程<目前在c++阶段, 因为最近参加新星计划算法赛道(白佬),所以加快了脚步,果然急迫感会增加动力 ——目标Windows,MySQL,Qt,数据结构与算法,Linux,多线程,会持续分享学习成果和小项目的 📖作者主页:热爱编程的

    2023年04月12日
    浏览(64)
  • 算法基础学习笔记——④前缀和\差分\双指针\位运算

    ✨ 博主: 命运之光 ✨ 专栏: 算法基础学习 目录 ✨前缀和 ✨一维前缀和 🍓一维前缀和模板: ✨二维前缀和 🍓二位前缀和模板: 前言: 算法学习笔记记录日常分享,需要的看哈O(∩_∩)O,感谢大家的支持! 原i:a[1] a[2] a[3] …a[n] 前缀和:s[i]=a[1]+a[2]+…+a[i] s[0]=0(方便处理

    2024年02月08日
    浏览(46)
  • 【C++算法图解专栏】一篇文章带你掌握差分算法

    ✍个人博客:https://blog.csdn.net/Newin2020?spm=1011.2415.3001.5343 📣专栏定位:为 0 基础刚入门数据结构与算法的小伙伴提供详细的讲解,也欢迎大佬们一起交流~ 📚专栏地址:https://blog.csdn.net/Newin2020/article/details/126445229 ❤️如果有收获的话,欢迎点赞👍收藏📁,您的支持就是我创

    2024年04月11日
    浏览(41)
  • 【数学】差分数组(一维差分)

     差分数组是指对一个 一维数组 进行差分操作得到的 新数组 。差分操作是指计算原数组中相邻元素之间的差异,并将这些差异作为新数组的元素。 具体而言,对于一个长度为n的一维数组x,其差分数组diff的第i个元素可以通过以下公式计算得到: diff[i] = x[i] - x[i-1] 其中,

    2024年02月15日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包