关注
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
//输入参数
int n;//输入n个数
int k;//有序对k对
vector<int> a;//输入序列a,包含1~n的n个数,有若干个数(不超过10个)是0
//输出参数
int cnt=0;//合法排列的数目
//输出perm数组,用于测试
void printperm(const vector<vector<int> > &perm)
{
for(int i=0;i<perm.size();i++)
{
for(int j=0;j<perm[0].size();j++)
cout<<perm[i][j]<<" ";
cout<<endl;
}
}
//将1~n全排列,放入二维数组perm
void creatperm(vector<vector<int> > &perm)
{
vector<int> temp;//1~n的临时vector
for(int i=1;i<=n;i++)
temp.push_back(i);
do{
perm.push_back(temp);
}while(next_permutation(temp.begin(), temp.end()));
}
//过滤,刷掉返回false,如果没有刷掉返回true
bool chooseperm(const vector<int> &permtemp)
{
for(int i=0;i<n;i++)
{
if(a[i])
{
if(a[i]!=permtemp[i])
return false;
}
}
return true;
}
//计算cnt
void count( const vector<vector<int> > &choose)
{
for(int i=0;i<choose.size();i++)
{
int ktemp=0;
vector<int> temp=choose[i];
for(int j=0;j<temp.size();j++)
{
for(int jj=j+1;jj<temp.size();jj++)
{
if(temp[j]<temp[jj])
ktemp++;
}
}
if(ktemp==k)
cnt++;
}
}
int main(){
//输入
cin>>n>>k;
for(int i=0;i<n;i++)
{
int temp;
cin>>temp;
a.push_back(temp);
}
//第一步
//先将1~n全排列(permutation),生成一个二维数组备用(每一行代表一种排序方式);
vector<vector<int> > perm;//用于存放全排列的二维vector
creatperm(perm);
cout<<"全排列:"<<endl;
printperm(perm);//测试生成是否正确
//第二步
//过滤该二维数组,选取满足特定位置上为输入序列中非0数的序列,生成新的二维数组;
vector<vector<int> > choose;//过滤之后的二维数组
for(int i=0;i<perm.size();i++)
{
if(chooseperm(perm[i]))
choose.push_back(perm[i]);
}
cout<<"过滤后:"<<endl;
printperm(choose);//测试生成是否正确
//第三步
//逐行验证其有序对是否为k,统计符合的个数;
count(choose);
cout<<"符合的排列个数"<<endl;
cout<<cnt<<endl;
}
查看原帖
点赞 1
相关推荐
走走停停666:我也知道大公司的HR都很忙,但是对影响到别人的事情就不能多上点心吗?本来天天批发一堆感谢信就烦,这又给我整这死出,懒得喷了
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 26届春招投递记录 #
54553次浏览 445人参与
# 多益网络工作体验 #
73908次浏览 316人参与
# 实习生的蛐蛐区 #
977864次浏览 4910人参与
# 找工作时的取与舍 #
138942次浏览 925人参与
# 27届实习投递记录 #
151173次浏览 1577人参与
# 多益网络求职进展汇总 #
108792次浏览 409人参与
# 一起聊华为 #
221473次浏览 972人参与
# 实习,不懂就问 #
221400次浏览 1721人参与
# 薪资一样,你会选择去大厂还是小公司 #
35556次浏览 133人参与
# 实习的内耗时刻 #
242810次浏览 1670人参与
# 求职中的尴尬瞬间 #
42389次浏览 125人参与
# 发工资后,你做的第一件事是什么 #
107771次浏览 348人参与
# 新凯来求职进展汇总 #
82915次浏览 195人参与
# 牛友投递互助,不漏校招机会 #
495548次浏览 5371人参与
# 非技术2024笔面经 #
515115次浏览 5058人参与
# 社会教会你的第一课 #
134460次浏览 874人参与
# 牛友们,签完三方你在忙什么? #
153852次浏览 1026人参与
# 你找工作的时候用AI吗? #
215051次浏览 1032人参与
# 听劝,这个简历怎么改 #
423253次浏览 1901人参与
# 哪个瞬间让你对大厂祛魅了? #
646261次浏览 4030人参与