B. Suffix Operations

原题链接
考察:枚举,前缀和
思路:
  先考虑不用任意改数字的方法,次数是所有数的绝对值之和.
  再枚举每一个将第\(i\)个数改为第\(i-1\)个数的情况,这里不要漏了将第\(1\)个数改为第\(2\)个数的情况.

Code

#include <iostream> 
#include <cstring>
using namespace std;
typedef long long LL;
const int N = 200010;
const LL INF = 1e14;
int n,a[N],b[N];
LL rsum[N],lsum[N];
int main()
{
	int T;
	scanf("%d",&T);
	while(T--)
	{
		scanf("%d",&n);
		for(int i=1;i<=n;i++) scanf("%d",&a[i]),b[i] = a[i]-a[i-1];
		if(n==1)
		{
			puts("0");
			continue;
		}
		a[n+1] = a[n-1];
		memset(rsum,0,sizeof rsum);
		memset(lsum,0,sizeof lsum);
		for(int i=n;i>=1;i--) rsum[i] = abs(b[i])+rsum[i+1];
		for(int i=2;i<=n;i++) lsum[i] = abs(b[i])+lsum[i-1];
		LL ans = min(rsum[3],rsum[2]);
		for(int i=2;i<=n;i++)
			ans = min(lsum[i-1]+abs(a[i+1]-a[i-1])+rsum[i+2],ans);
		printf("%lld\n",ans);
	}
	return 0;
}

上一篇:iText7解套(三)列表中文中文序号


下一篇:thinkphp6开启控制器后缀