93. 递归实现组合型枚举

题目

思路

一个m个坑位,填n个数,就依次往里放就好了

同时判断一下升序,当前这个数比前一个数大就可以了

代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int n, m;
int ans[30];
int f[30]={0};
void dfs(int v)
{
	if (v > m) 
	{
		for (int i = 1; i <= m; i ++ )
		{
			cout << ans[i] << " ";
		}
		cout << endl;
		return;
	}
	for (int i = 1; i <= n; i ++ )
	{
		if (!f[i] && i > ans[v - 1])
		{
			f[i] =  1;
			ans[v] = i;
			dfs(v + 1);
			f[i] = 0;
			ans[v] = 0;
		}
		
	}
}
int main()
{
	cin >> n >> m;
	dfs(1);
	return 0;
 } 
相关推荐
用户0099383143012 分钟前
代码随想录算法训练营第十三天 | 二叉树part01
数据结构·算法
shinelord明6 分钟前
【再谈设计模式】享元模式~对象共享的优化妙手
开发语言·数据结构·算法·设计模式·软件工程
დ旧言~12 分钟前
专题八:背包问题
算法·leetcode·动态规划·推荐算法
_WndProc30 分钟前
C++ 日志输出
开发语言·c++·算法
努力学习编程的伍大侠43 分钟前
基础排序算法
数据结构·c++·算法
TENET信条1 小时前
代码随想录 day50 第十一章 图论part01
图论
XiaoLeisj1 小时前
【递归,搜索与回溯算法 & 综合练习】深入理解暴搜决策树:递归,搜索与回溯算法综合小专题(二)
数据结构·算法·leetcode·决策树·深度优先·剪枝
Jasmine_llq2 小时前
《 火星人 》
算法·青少年编程·c#
闻缺陷则喜何志丹2 小时前
【C++动态规划 图论】3243. 新增道路查询后的最短距离 I|1567
c++·算法·动态规划·力扣·图论·最短路·路径