社区讨论
求解这个程序为啥RE八个点..
P1088[NOIP 2004 普及组] 火星人参与者 2已保存回复 1
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 1 条
- 当前快照
- 1 份
- 快照标识符
- @mi6mnwnx
- 此快照首次捕获于
- 2025/11/20 07:22 4 个月前
- 此快照最后确认于
- 2025/11/20 07:22 4 个月前
第一个数据就是样例
然而样例过了不知道为啥第一个WA..
CPP#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<vector>
using namespace std;
const int N=100000+5;
const int fact[150]={1, 1, 2, 6, 24, 120, 720, 5040, 40320, 362880, 3628800};
int n,m,a[N],l[N],sum=0;
char s[N];
int Cantor(char s[])
{
int ans=0,len=strlen(s);
for(int i=0;i<len;i++)
{
int t=0;
for(int j=i+1;j<len;j++)
if(s[i]>s[j]) ++t;
ans+=t*fact[len-i-1];
}
return ans+1;
}
vector<int> deCantor(int n,int m)//n个元素,第m个排列
{
m--;
vector<int> a;
vector<int> v;
for(int i=1;i<=n;i++)
v.push_back(i);
for(int i=n;i>0;i--)
{
int t=m/fact[i-1];
m%=fact[i-1];
sort(v.begin(),v.end());
a.push_back(v[t]);
v.erase(v.begin()+t);
}
return a;
}
int main()
{
scanf("%d%d\n",&n,&m);
for(int i=0;i<2*n;i++)
{
char c=getchar();
if(c!=' '&&c!=10)
s[i/2]=c;
}
int lens=strlen(s);
int h=Cantor(s);
m+=h;
vector<int> ans=deCantor(n,m);
int len_v=ans.size();
for(int i=0;i<len_v;i++)
printf("%d ",ans[i]);
printf("\n");
return 0;
}
回复
共 1 条回复,欢迎继续交流。
正在加载回复...