首页 > 其他分享 >CF1918G Permutation of Given 题解

CF1918G Permutation of Given 题解

时间:2024-02-07 23:23:55浏览次数:18  
标签:Given int 题解 sum 元素 CF1918G 已知 len 序列

总体思路

本题通过每次在已知序列中加入 \(2\) 个元素的方法,可以构造出满足条件的序列 \(A\) ,这里提供一种新的构造方法。

性质

因为序列 \(A\) 中所有元素构成的可重集与序列 \(B\) 中所有元素构成的可重集完全相等,所以 \(A\) 中所有元素之和与 \(B\) 中所有元素之和相等。

\[ \sum_{i=1}^{n}B_i=\sum_{i=1}^{n}A_i \]

题目中除 \(A_1\) 和 \(A_n\) 以外,所有序列 \(A\) 中的元素都对序列 \(A\) 元素的总和产生一个两份贡献。

可以表示为:

\[\sum_{i=1}^{n}B_i = A_1+A_n+2 \cdot \sum_{i=2}^{n-1}A_i \]

经过等量代换,我们发现序列 \(A\) 具有这样一个性质

\[\sum_{i=1}^{n}A_i = A_1+A_n+2 \cdot \sum_{i=2}^{n-1}A_i \]

\[\sum_{i=2}^{n-1}A_i=0 \]

构造

我们可以由此从已知序列,推出长度比此序列多 \(2\) 的新序列,具体方法如下:

我们记已知序列 \(A\) 的长度为 \(len\)。

当我们在一个已知序列 \(A\) 加入两个新元素时,假设构造出的新序列 \(A'\) 仍然满足条件。

那么根据先前推导的性质,我们可以求出新加入的第一个数:

\[A'_{len+1}=0-\sum_{i=2}^{len}A_i \]

假设已知序列 \(B\) 中最后一个元素为 \(x\) ,不妨设与它相对应的元素为 \(y\)。

当我们加入新元素时,会产生新的贡献关系,从而破坏元素 \(x\) 和 \(y\) 的对应关系。

此时没有元素与 \(x\) 对应,又因为元素 \(A'_{len+1}\) 已经与 \(B'_{len+2}\) 对应,所以只能让元素 \(A'_{len+2}\) 与 \(x\) 对应:

此时,我们发现除了 \(y\) 以外的元素都一一对应,那么 \(B'_{len+1}\) 自然就可以与 \(y\) 对应了。

至此,所有元素均完成配对,成功由已知序列 \(A\) 构造出比此序列多 \(2\) 的新序列 \(A'\) ,且 \(A'\) 满足题意。

实现

我们发现,在 \(n<7\) 内不能构造出一组 \(n\) 为奇数的序列 \(A\) ,此时无解。

所以我们通过构造出两组最短序列 \(A\) ,一组 \(n\) 为奇数,一组 \(n\) 为偶数,按照上文提到的方式构造即可。

\(n\) 为偶数:

2
-1 1

\(n\) 为偶数:

7
-5 8 1 -3 -4 -2 5

代码实现:

#include<bits/stdc++.h>
using namespace std;

int n;
int a[1000010];
int b[1000010];
int sum[1000010];

void init(){
	if(n%2==0) a[1]=-1,a[2]=1;
	else a[1]=-5,a[2]=8,a[3]=1,a[4]=-3,a[5]=-4,a[6]=-2,a[7]=5;
	for(int i=1;i<=(n%2?7:2);i++){
		if(i!=1) b[i-1]+=a[i];
		b[i+1]+=a[i];
		sum[i]=sum[i-1]+a[i];
	}
}

int main(){
	cin>>n;
	if(n%2&&n<7){
		cout<<"NO"<<endl;
		return 0;
	}
	
	init();
	cout<<"YES"<<endl;
	
	for(int k=(n%2?8:3);k<=n;k+=2){
		
		int s=sum[k-1]-sum[1];//cout<<s<<endl;
		
		a[k]=-s;
		b[k-1]+=a[k];
		b[k+1]+=a[k];
		
		a[k+1]=b[k-1];
		b[k]+=a[k+1];
		b[k+2]+=a[k+1];
		
		sum[k]=sum[k-1]+a[k];
		sum[k+1]=sum[k]+a[k+1];
		
	}
	
	for(int i=1;i<=n;i++)
		cout<<a[i]<<" ";
	
	return 0;
}

标签:Given,int,题解,sum,元素,CF1918G,已知,len,序列
From: https://www.cnblogs.com/dmxm/p/18011463

相关文章

  • SP277 CTGAME - City Game 题解
    题目传送门前置知识单调栈解法令\(f_{i,j}(1\lei\len,1\lej\lem)\)表示从\((1,j)\)到\((i,j)\)中以\((i,j)\)结尾的均为F的子串长度,即\((i,j)\)上面可延伸的最大距离(子矩形的长)。用单调栈的第一维存储子矩形的长,第二维存储子矩形的宽。考虑依次枚举每一......
  • qoj8171 Cola 题解
    题目链接点击打开链接题目解法很牛的题!!!会不了一点令\(pref_i\)表示第\(i\)轮知道了前缀\([1,...,i]\)考虑怎样的\(pref\)序列是合法的(即采用最优策略):\(pref_0=0\)\(\forall_{i\in[0,n-1]}\;pref_i\lepref_{i+1}\)\(pref\)中\(x\)的出现次数\(\len-x-1\),因......
  • [AGC021E] Ball Eat Chameleons 题解
    Description有\(n\)只变色龙,一开始都是蓝色。现在你喂了\(k\)次球,每次指定一只变色龙吃下你指定颜色的球。一只变色龙从蓝色变成红色当且仅当它吃的红球比蓝球多;一只变色龙从红色变成蓝色当且仅当它吃的蓝球比红球多。求最后能使所有变色龙都变成红色的方案数。两个方案......
  • AT_abc270_g [ABC270G] Sequence in mod P 题解
    题目传送门前置知识大步小步算法解法递推式为\(x_{n}=(ax_{n-1}+b)\bmodp\),发现可以统一消去\(\bmodp\),只在最后参与计算。以下过程省去模运算。当\(x_{0}=t\)时,则\(n=0\)即为所求。当\(a=0,x_{0}\net\)时,递推式转化为\(x_{n}=b\bmodp\)。若\(b=t\),则......
  • UVA10225 Discrete Logging 题解
    题目传送门前置知识大步小步算法题意多组询问,每次询问依次给定\(p,a,b\),求\(a^{x}\equivb\pmod{p}\)的最小非负整数解,其中\(a,p\)互质。解法BSGS板子题,不做过多介绍。貌似本题比P3846[TJOI2007]可爱的质数/【模板】BSGS和BZOJ3239DiscreteLogging数据较强......
  • [AGC041F] Histogram Rooks 题解
    题目链接点击打开链接题目解法好牛(难)的题!!!所有都被覆盖不难想到容斥暴力的容斥是钦定集合\(S\)中的位置都没被覆盖,然后把不能填棋子的点都去掉,假设剩下的不受限制的点的个数为\(c\),则答案为\(\sum2^c(-1)^{|S|}\)这个暴力是很难直接优化的如果一列被有点被钦定了,那么......
  • 【洛谷 P2670】[NOIP2015 普及组] 扫雷游戏 题解(模拟)
    [NOIP2015普及组]扫雷游戏题目背景NOIP2015普及组T2题目描述扫雷游戏是一款十分经典的单机小游戏。在行列的雷区中有一些格子含有地雷(称之为地雷格),其他格子不含地雷(称之为非地雷格)。玩家翻开一个非地雷格时,该格将会出现一个数字——提示周围格子中有多少个是地雷格。游戏的......
  • UVA12024 Hats 题解
    题目传送门前置知识错位排列题意有\(t\)组询问,每次询问给定一个\(n\),表示有\(n\)个人,每人各有一个属于自己的帽子,求所有人都带错帽子的概率(不要求约分至最简形式)。解法错排板子题,\(\dfrac{D_{n}}{A_{n}^{n}}\)即为所求。代码#include<bits/stdc++.h>usingnamespac......
  • CF231E 题解
    本文采用CCBY-NC-SA4.0协议发布。前言提供一个圆方树做法。孩子圆方树学傻了,忘了还有缩点这回事。正文建圆方树。考虑一条圆方树上的路径,哪些点对答案有贡献:方点,这表示路径经过一个环,方案数\(\times2\).旁边有方点的圆点。这表示走到这时可以选择在环上绕一圈,方......
  • 洛谷P10136 暨 USACOJan2024S T3 题解
    题意简述原题已经很简了,没有什么简述的必要了。思维路径请注意本题解可以保证正确性但不保证如果有极端的Hack数据能够通过。拿到这道题上来的暴力想必是很容易的,即枚举每个\(L\)判断是否合法。接着我们就考虑优化,减少需要枚举的\(L\)的量。题目中要求余数最多有\(3\)......