CH0302 递归/非递归实现组合型枚举
2022/1/27 23:36:07
本文主要是介绍CH0302 递归/非递归实现组合型枚举,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
描述
从 1~n 这 n 个整数中随机选出 m 个,输出所有可能的选择方案。n>0, 0<=m<=n, n+(n-m)<=25。
输入格式
两个整数n,m。
输出格式
按照从小到大的顺序输出所有方案,每行1个。
首先,同一行内的数升序排列,相邻两个数用一个空格隔开。其次,对于两个不同的行,对应下标的数一一比较,字典序较小的排在前面(例如1 3 9 12排在1 3 10 11前面)。
样例输入
5 3
样例输出
1 2 3 1 2 4 1 2 5 1 3 4 1 3 5 1 4 5 2 3 4 2 3 5 2 4 5 3 4 5
1 #include<bits/stdc++.h> 2 using namespace std; 3 vector<int>f; 4 int main() 5 { 6 int n,m; 7 cin>>n>>m; 8 function<void(int,int)>dfs=[&](int u,int k) 9 { 10 if(!k) 11 { 12 for(auto &p:f)printf("%d%c",p,' '); 13 printf("\n"); 14 return; 15 } 16 if(u+k>n+1||u>n)return; 17 f.push_back(u); 18 dfs(u+1,k-1); 19 f.pop_back(); 20 dfs(u+1,k); 21 }; 22 dfs(1,m); 23 24 return 0; 25 }
这篇关于CH0302 递归/非递归实现组合型枚举的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-26RocketMQ入门指南:搭建与使用全流程详解
- 2024-11-26RocketMQ入门教程:轻松搭建与使用指南
- 2024-11-26手写RocketMQ:从入门到实践的简单教程
- 2024-11-25【机器学习(二)】分类和回归任务-决策树(Decision Tree,DT)算法-Sentosa_DSML社区版
- 2024-11-23增量更新怎么做?-icode9专业技术文章分享
- 2024-11-23压缩包加密方案有哪些?-icode9专业技术文章分享
- 2024-11-23用shell怎么写一个开机时自动同步远程仓库的代码?-icode9专业技术文章分享
- 2024-11-23webman可以同步自己的仓库吗?-icode9专业技术文章分享
- 2024-11-23在 Webman 中怎么判断是否有某命令进程正在运行?-icode9专业技术文章分享
- 2024-11-23如何重置new Swiper?-icode9专业技术文章分享