差分--https://www.cnblogs.com/MS903/p/11244969.html
问题 A: 鸭子游戏
时间限制: 1 Sec 内存限制: 128 MB
[提交] [状态]
题目描述
KeineDuck热爱游戏。最近她沉迷于一款名叫“DuckGame”的纸牌。
DuckGame是一款颇有难度的纸牌游戏。在每一轮开始前,会有一些纸牌摆放在玩家的面前,从左到右的第孩堆有ai张纸牌。每张纸牌都是一样的。
游戏开始后,玩家可以选择一个区间[l,r](包括两个端点),并且把这个区中的每一堆纸牌增加或拿走一张纸牌。若每堆纸牌的个数都相同了,玩家即可获胜。我们称这个步骤为一次操作。
KeineDuck想要知道,她至少要进行多少次操作,才能够获胜。
输入
第一行输入一个正整数n,表示有多少堆纸牌。
接下来一行共n个数,第i个数表示第i堆有多少纸牌。
输出
一个整数,表示至少要多少次操作。
样例输入 Copy
5
2 1 2 3 3
样例输出 Copy
2
提示
样例解释
KeineDuck第一次选择了区间[2,2],将其中的每堆增加了一张纸牌。
KeineDuck第二次选择了区间[4,5],将其中的每堆拿走了一张纸牌。
总共用了2次操作。
对于10%的数据,n=2。
对于另外20%的数据,n=6。
对于另外10%的数据,n=10000,且纸牌的数量从左到右单调递增。
对于另外10%的数据,n=100000,且每堆纸牌的个数不超过2。
对于另外20%的数据,n=100000,且每堆纸牌的个数不超过20。
对于最后30%的数据,n=2000000,且每堆纸牌的个数不超过1000。
#include<bits/stdc++.h>
typedef unsigned long long ULL;
using namespace std;
typedef long long ll;
const int N=2000005;
const int mod=2000005;
int a[N],b[N],p[N];
int main()
{
int n;
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
scanf("%d",a+i);
}
b[1]=a[1];
b[1+n]=-a[n];
ll ans=0,sum=0;
for(int i=2;i<=n;i++)
{
b[i]=a[i]-a[i-1];
if(b[i]>0) sum+=b[i];
else ans-=b[i];
}
printf("%lld",max(sum,ans));
return 0;
}