自学内容网 自学内容网

全排列和组合数区分

全排列传送门
组合数传送门

共同点:

  • 都是dfs深搜
  • 区别点在于组合数要去重 在dfs函数中加一个条件参数
bool num[23];//判断重复数组
int ans[23];//返回结果数组
//组合数给定参数n和长度k的组合‘
int k,n;
dfs(int deep,int last)
{
if(deep>k){
for(int i=1;i<=k;i++) cout<<res<<" ";
cout<<endl;
return;
}
for(int i=1;i<=n;i++){
if(num[i]==false&&i>last){//全排列是没有i>last的
num[i]=true;
ans[deep]=i;//存值
dfs(deep+1,i);
num[i]]=false;//回溯
}
}
}
int main(
{
cin>>n>>k;
dfs(1,0);
return 0;
}

原文地址:https://blog.csdn.net/2302_78926002/article/details/142708558

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!