ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

CF1612B Special Permutation

2022-01-09 23:00:57  阅读:185  来源: 互联网

标签:CF1612B const int Permutation read sim ans Special neq


洛谷题面

题目大意

构造一个长度为 \(n\) 的排列 \(p\),使得 \(p_{[1,{\frac{n}{2}}]}\) 中的最小值为 \(a\),使得 \(p_{[{\frac{n}{2}} + 1, n]}\) 中的最大值为 \(b\)。

如果没有合法的排列,输出 \(-1\)。

题目分析

将答案序列存到 \(ans\) 数组中,令 \(m=\dfrac{n}{2}\)。

让 \(ans[1]=a,ans[m+1]=b\),随后我们只需要在 \(2\sim m\) 和 \(m+1\sim n\) 中填入数字即可。

填的时候注意不要重复,可以采取倒序的方式填,如果当前填的数与 \(a\) 或 \(b\) 相等那么不能填,再将数减一。

最后扫一遍序列,如果 \(\min\limits_{i=1}^{m}\{ans[i]\}\neq a,\max\limits_{i=m+1}^n\{ans[i]\}\neq b\) 表示不满条件。

代码

//2022/1/9

using namespace std;

const int INF=0x3f3f3f3f;

const int ma=105;

int ans[ma];

int T,n,a,b;

inline void solve()
{
	n=read(),a=read(),b=read();
	
	int m=n/2;
	
	mst(ans,0);
	
	ans[1]=a,ans[m+1]=b;
	
	int num=n+1;
	
	for(register int i=1;i<=n;i++)
	{
		if(ans[i]==0)
		{
			num--;
			
			while(num==a || num==b)
			{
				num--;
			}
			
			ans[i]=num;
		}
	}
	
	int minn=INF,maxx=-INF;
	
	for(register int i=1;i<=n;i++)
	{
		if(i<=m)
		{
			minn=min(minn,ans[i]); 
		}
		
		else
		{
			maxx=max(maxx,ans[i]);
		}
	}
	
	if(minn!=a || maxx!=b)
	{
		puts("-1");
	}
	
	else
	{
		blow(ans,1,n," ");
		
		enter();
	}
}

int main(void)
{
	T=read();
	
	while(T--)
	{
		solve();
	}
	
	return 0;
}

标签:CF1612B,const,int,Permutation,read,sim,ans,Special,neq
来源: https://www.cnblogs.com/Coros-Trusds/p/15782631.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有