codeforces1374F Cyclic Shifts Sorting

本文详细解析了 Codeforces 1374F 题目的解题思路,通过离散化和逆序对的奇偶性判断是否可以完成数组排序,分享了一种递归构造解法。

https://codeforces.com/problemset/problem/1374/F

菜哭.jpg

有一个显然的想法就是,我们可以离散化后,把前n-2个位置全部确定,要么就是往前2格,往前一格就做两次同样的操作

然后就是a[n-1]>a[n]的情况,如果a[n]=a[n-2]的话,就可以直接换,否则,就不知道怎么办了。。。。

看了题解,发现如果a[n-1]>a[n],那么实际上就是要让a[n-2]和a[n-1]换位,而如果想让a[n-2]和a[n-1]换位,需要在n-3的地方做两次操作,而且a[n-3]还必须等于a[n-2],否则,则需要a[n-3]和a[n-2]换位。。。。

这样一直递归下去,我们就知道,如果有两个相同的值,一定是可以构造成功的

题解一开始开提到,如果没有相同的值,那么由于3元组shuffle,逆序对的总数的奇偶性是不会改变的,所以如果是奇数个逆序对,必然不可以完成排序

感觉以后这种随意shuffle的问题要往逆序对的奇偶性上想一想

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

const int maxl=3e5+10;

int n,m,cas,k,cnt,tot,ans;
int a[maxl],b[maxl],c[maxl],opt[maxl];
int res[maxl];
char s[maxl];
bool in[maxl]; 

inline void prework()
{
	scanf("%d",&n);tot=0;
	for(int i=1;i<=n;i++)
		scanf("%d",&a[i]),b[i]=a[i];
	sort(b+1,b+1+n);
	tot=unique(b+1,b+1+n)-b-1;
	for(int i=1;i<=tot;i++)
		res[i]=0;
	for(int i=1;i<=n;i++)
		a[i]=lower_bound(b+1,b+tot+1,a[i])-b,res[a[i]]++;
} 

inline void shuf(int i)
{
	int x=a[i],y=a[i+1],z=a[i+2];
	a[i]=z;a[i+1]=x;a[i+2]=y;
}

inline void mainwork()
{
	int now=1,id;ans=0;
	for(int i=1;i<=n-2;i++)
	{
		for(int j=i;j<=n;j++)
		if(a[j]==now)
		{
			id=j;
			break;
		}
		while(id>=i+2)
		{
			opt[++ans]=id-2;shuf(id-2);
			id-=2;
		}
		if(id==i+1)
		{
			if(a[i-1]==now)
			{
				opt[++ans]=id-2;shuf(id-2);
				id-=2;
			} 
			else
			{
				opt[++ans]=i;shuf(i);
				opt[++ans]=i;shuf(i);
				id-=1;
			}
		}
		res[now]--;
		if(!res[now])
			now++;
	}
	if(a[n-1]>a[n])
	{
		if(a[n]==a[n-2])
			opt[++ans]=n-2,shuf(n-2);
		else
		{
			for(int i=n-3;i>=1;i--)
			if(a[i]==a[i+1])
			{
				for(int j=i;j<=n-2;j++)
				{
					opt[++ans]=j,shuf(j);
					opt[++ans]=j,shuf(j);
				}
				return;
			}
			ans=-1;
		}
	} 
}

inline void print()
{
	if(ans>n*n) ans=-1;
	if(ans==-1)
		puts("-1");
	else if(ans==0)
		puts("0"),puts("");
	else
	{
		printf("%d\n",ans);
		for(int i=1;i<=ans;i++)
			printf("%d%c",opt[i]," \n"[i==ans]);
	}
}

int main()
{
	int t=1;
	scanf("%d",&t);
	for(cas=1;cas<=t;cas++)
	{
		prework();
		mainwork();
		print();
	}
	return 0;
}

 

该数据集通过合成方式模拟了多种发动机在运行过程中的传感器监测数据,旨在构建一个用于机械系统故障检测的基准资源,特别适用于汽车领域的诊断分析。数据按固定时间间隔采集,涵盖了发动机性能指标、异常状态以及工作模式等多维度信息。 时间戳:数据类型为日期时间,记录了每个数据点的采集时刻。序列起始于2024年12月24日10:00,并以5分钟为间隔持续生成,体现了对发动机运行状态的连续监测。 温度(摄氏度):以浮点数形式记录发动机的温度读数。其数值范围通常处于60至120摄氏度之间,反映了发动机在常规工况下的典型温度区间。 转速(转/分钟):以浮点数表示发动机曲轴的旋转速度。该参数在1000至4000转/分钟的范围内随机生成,符合多数发动机在正常运转时的转速特征。 燃油效率(公里/升):浮点型变量,用于衡量发动机的燃料利用效能,即每升燃料所能支持的行驶里程。其取值范围设定在15至30公里/升之间。 振动_X、振动_Y、振动_Z:这三个浮点数列分别记录了发动机在三维空间坐标系中各轴向的振动强度。测量值标准化至0到1的标度,较高的数值通常暗示存在异常振动,可能与潜在的机械故障相关。 扭矩(牛·米):以浮点数表征发动机输出的旋转力矩,数值区间为50至200牛·米,体现了发动机的负载能力。 功率输出(千瓦):浮点型变量,描述发动机单位时间内做功的速率,取值范围为20至100千瓦。 故障状态:整型分类变量,用于标识发动机的异常程度,共分为四个等级:0代表正常状态,1表示轻微故障,2对应中等故障,3指示严重故障。该列作为分类任务的目标变量,支持基于传感器数据预测故障等级。 运行模式:字符串类型变量,描述发动机当前的工作状态,主要包括:怠速(发动机运转但无负载)、巡航(发动机在常规负载下平稳运行)、重载(发动机承受高负荷或高压工况)。 数据集整体包含1000条记录,每条记录对应特定时刻的发动机性能快照。其中故障状态涵盖从正常到严重故障的四级分类,有助于训练模型实现故障预测与诊断。所有数据均为合成生成,旨在模拟真实的发动机性能变化与典型故障场景,所包含的温度、转速、燃油效率、振动、扭矩及功率输出等关键传感指标,均为影响发动机故障判定的重要因素。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值