全排列和组合数区分

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

共同点:

  • 都是dfs深搜
  • 区别点在于组合数要去重 在dfs函数中加一个条件参数
cpp 复制代码
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;
}
相关推荐
小南家的青蛙4 分钟前
LeetCode第773题 - 滑动谜题
算法·leetcode·职场和发展
Felven14 分钟前
C. Isamatdin and His Magic Wand!
c语言·数据结构·算法
AndrewHZ17 分钟前
【芯芯相印】什么是算法定点化?
pytorch·算法·芯片设计·模型量化·定点化·芯片算法·逻辑电路
数据科学小丫20 分钟前
算法:线性回归
算法·回归·线性回归
剪一朵云爱着29 分钟前
PAT 1131 Subway Map
算法·pat考试·图论
CoderYanger29 分钟前
动态规划算法-子序列问题(数组中不连续的一段):30.最长数对链
java·算法·leetcode·动态规划·1024程序员节
啦哈拉哈31 分钟前
【Python】知识点零碎学习1
数据结构·python·算法
多恩Stone34 分钟前
【3DV 进阶-10】Trellis 中的表示 SLat 理解(1)
人工智能·python·算法·3d·aigc
京井35 分钟前
从中序与后序遍历序列构造二叉树解题思路
c语言·算法
Han.miracle38 分钟前
算法--003快乐数
数据结构·算法·快乐数