比赛 CSP2023-J模拟赛 评测结果 ATTTATATTTTTTEEEEEEE
题目名称 排列变换 最终得分 15
用户昵称 朱子瑜 运行时间 13.767 s
代码语言 C++ 内存使用 6.65 MiB
提交时间 2023-10-18 18:49:44
显示代码纯文本
#include<bits/stdc++.h>
using namespace std;
int n,maxn=-1,tmp,k;
struct ai{
	int id,num;
}a[100000];
int t(){
	int o=0;
	for(int i=1;i<=n;i++){
		if(a[i].num >=a[i].id )o++;
	}
	return o;
}
bool cmp(ai x,ai y){
	return x.id <y.id ;
}
int main(){
	freopen("permutrans.in","r",stdin);
	freopen("permutrans.out","w",stdout);
	ios::sync_with_stdio(0);
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>a[i].num ;
		a[i].id =i;
		if(a[i].num >=a[i].id )maxn++;
	}
	int u=n-1,w=n;
	while(u--){
		a[n].id =1;
		for(int i=1;i<=w-1;i++)a[i].id++;
		sort(a+1,a+n+1,cmp);
//		for(int i=1;i<=n;i++)cout<<a[i].id <<" "<<a[i].num <<endl;
//		cout<<endl;
		tmp++;
		int y=t();
//		cout<<tmp<<" "<<y<<endl<<endl;
		if(maxn<y)maxn=y,k=tmp;
	}
	cout<<maxn<<" "<<k;
	return 0;
}