差分数组(简单易懂)

一、什么是差分数组?

差分数组本质上来说就是一个数组,可以用O(1)的时间处理区间修改。

二、差分数组的定义式

设原数组为a数组,差分数组为d数组,则对于i∈[2,n],都有d[i]=a[i]-a[i-1].

三、差分数组的性质

1.当我们需要更新区间[l,r]时候(仅指加减运算),我们仅仅可以只更新d[l]+=x,d[r+1]-=x;

2.当我们需要单独查询原数组一个点的值的时候,我们不难发现出令eq?S_%7Bn%7D为d[i]的前缀和,那么a[i]=eq?S_%7Bi%7D;

3.当我们需要求原数组的前缀和的时候,我们可以设前x项和为eq?sum_%7Bx%7D,则有:eq?sum_%7B_%7Bx%7D%7D%3D%5Csum_%7Bi%3D1%7D%5E%7Bx%7Da%5Bi%5D%3D%5Csum_%7Bi%3D1%7D%5E%7Bx%7D%20%5Csum_%7Bj%3D1%7D%5E%7Bi%7Dd%5Bi%5D%3D%5Csum_%7Bi%3D1%7D%5E%7Bx%7D%28x-i+1%29d%5Bi%5D

39d8a9a263764608b834af8e2f1ac324.png 

四、例题:

AcWing 1952. 金发姑娘和 N 头牛

AC代码:

#include <iostream>
#include <cstring>
#include <algorithm>
#include <map>
using namespace std;
map<int,int>mapp;
int main(){
    int n,x,y,z;
    cin >> n >> x >> y >> z;
    int xx,yy;
    for (int i = 1; i <= n; i ++ )
    {
        cin >> xx >> yy;
        mapp[0]+=x;
        mapp[xx]=mapp[xx]-x+y;
        mapp[yy+1]=mapp[yy+1]-y+z;
    }
    int maxn=0;
    int sum=0;
    for(map<int,int>::iterator iter=mapp.begin();iter!=mapp.end();iter++){
        sum+=iter->second;        
        maxn=max(maxn,sum);
    }
    cout<<maxn;
    return 0;
}

 

 

posted @ 2022-04-24 00:21  YutaoJiang  阅读(21)  评论(0编辑  收藏  举报  来源