时间:2021-05-20
前言
在平时的算法的题目中,时常会遇到组合数相关的问题,暴力枚举。在N个数中挑选M个数出来。利用for循环也可以处理,但是可拓展性不强,于是写这个模板供以后参考。
两个函数和全局变量可以直接用。
代码:
#include<iostream>#include<cstdio> #define N 10 //被选择的数目#define M 5 //要选出来的数目 using namespace std;int vis[N+1]; //标志,int ans=0; //含有的组合数 的数量int num[M+1]; //选出来的数放在num数组里面 void solve() { //在solve函数里面处理 for(int i=1; i<M+1; i++) cout<<num[i]<<" "; cout<<endl;} void dfs(int index) { //挑选的第index+1个数 if(index == M) { solve(); ans++; return ; } for(int i=num[index]+1; i<N+1; i++) { if(!vis[i]) { vis[i] = 1; num[index+1] = i; dfs(index+1); vis[i] = 0; } }} int main(){ dfs(0); //回溯开始 cout<<endl<<ans; return 0;}可以发现利用回溯法挑选的有一个优势在于,输出的数组是经过排序的。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
C语言练习题从键盘输入两个数m和n,求其最大公约数和最小公倍数。实现方法如下:main(){intm,n,a,b;intp,r,temp;printf("Ple
1.前言本文介绍了常用的排列组合算法,包括全排列算法,全组合算法,m个数选n个组合算法等。2.排列算法常见的排列算法有:(A)字典序法(B)递增进位制数法(C)
具体题目是这样的: 从1--9中选取N个数字,组成不重复的N位数,从小到大进行编号,当输入其中任何一个数M时,能找出该数字对应的编号。如N=3,M=213.输
具体题目是这样的: 从1--9中选取N个数字,组成不重复的N位数,从小到大进行编号,当输入其中任何一个数M时,能找出该数字对应的编号。如N=3,M=213.输
本文实例讲述了Python基于回溯法子集树模板解决数字组合问题。分享给大家供大家参考,具体如下:问题找出从自然数1、2、3、...、n中任取r个数的所有组合。例