Libre OJ P2332「JOI 2017 Final」焚风现象【差分思想】By cellur925

题目传送门

这道题开始看起来会很晕...\(qwq\)。首先我们要明确题目中的海拔&&温度。温度是受海拔影响的,每次改变的是海拔,我们求的是温度。

我们开始读入的时候便可以处理出开始\(N\)位置的温度以及各个位置的海拔差。每次读入影响的是一段区间,区间内的相对海拔是不变的因此温度也不会变。只有区间的边界可能受到影响。因此我们只要处理边界就行了:这便是差分的思想

比如有\([l,r]\)区间需要处理,那么我们把\(l\)位置的原答案减去,把\(l\)位置的海拔改变,并加上新答案。再对\(r+1\)位置做类似的处理,其他部分不会受到影响。

\(Code\)

#include<cstdio>
#include<algorithm>

using namespace std;
typedef long long ll;

int n,Q,las;
ll s,t,ans,a[200090];

ll cal(ll x)
{
    return x>0 ? -x*s : -x*t;
}

int main()
{
    scanf("%d%d%lld%lld",&n,&Q,&s,&t);
    scanf("%d",&las);
    for(int i=1;i<=n;i++)
    {
        int x=0;
        scanf("%d",&x);
        a[i]=x-las;
        las=x;
        ans+=cal(a[i]);
    }
    while(Q--)
    {
        int x=0,y=0,z=0;
        scanf("%d%d%d",&x,&y,&z);
        ans-=cal(a[x]);
        a[x]+=z;
        ans+=cal(a[x]);
        if(y==n){printf("%lld\n",ans);continue;}
        ans-=cal(a[y+1]);
        a[y+1]-=z;
        ans+=cal(a[y+1]);
        printf("%lld\n",ans);
    }
    return 0;
}

转载于:https://www.cnblogs.com/nopartyfoucaodong/p/9897397.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值