排列组合算法(基于c++实现)
排列

第一层S1表示第一个数分别与第1、2、3个数交换位置,如123是1和第一个数1交换,213是1和第二个数2交换,321是1和第三个数交换
第二层S2是第二个数分别与第2、3个数交换位置。则最后一层的所有叶子节点,即为全排列的所有结果。第k层中的节点Sk就是父节点中的第k个数,分别与第k、k+1...n个数交换位置。
也可用stl的next_permutation()和perv_permutation()
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std; template <class T>
class Perm
{
public:
//由于vector本身就是模板,在其模板参数未确定之前,也就是具体类型没有确定之前,这个T是未知的
//typename就是告诉编译器先不管具体类型,等模板实例化的时候再确定
void perm(vector<T> &a,typename vector<T>::iterator begin);
bool is_swap(typename vector<T>::iterator i,typename vector<T>::iterator j);
private:
static int i;
};
template <class T>
int Perm<T>::i=; template <class T>
bool Perm<T>::is_swap(typename vector<T>::iterator i,typename vector<T>::iterator j)
{
for(typename vector<T>::iterator k=i;k!=j;++k)
if(*k==*j)
return false;
return true; } template <class T>
void Perm<T>::perm(vector<T> &a,typename vector<T>::iterator begin)
{
if(begin==a.end())
{
cout<<" 第"<<++i<<" 个排列为:";
for_each(a.begin(),a.end(),[](int i)
{
cout<<i<<" ";
});
cout<<endl;
}
for(auto i=begin;i!=a.end();++i)
{
if(!is_swap(begin,i))
continue;
swap(*begin,*i);
perm(a,begin+);
swap(*begin,*i);
}
} int main()
{
vector<int> a;
int n;
cout<<" 请输入元素的个数:"<<endl;
cin>>n;
for(int i=;i<n;++i)
{
int t;
cin>>t;
a.push_back(t);
} Perm<int> p;
p.perm(a,a.begin());
return ;
}
组合
第一层S1中的节点是数组中的所有数字,第二次S2中的节点是分别从父节点的下一个位置开始。因为这个例子中m=2,所以共有2层。从第一层到第二层,深度遍历这颗树,即可得到所有组合。

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std; template <class T>
class Combine
{
public:
void combine(vector<T> a,int begin,int num);
private:
vector<T> r;
}; template <class T>
void Combine<T>::combine(vector<T> a,int begin,int num)
{
if(a.empty())
{
cout<<" 要组合的数组为空."<<endl;
return;
}
if(num==)
{
for_each(r.begin(),r.end(),[](T i)
{
cout<<i<<" ";
});
cout<<endl;
return;
}
for(int i=begin;i<a.size();++i)
{
r.push_back(a.at(i));
combine(a,i+,num-);
r.pop_back();
}
} int main()
{
vector<int> a;
int n;
cout<<" 请输入元素的个数:"<<endl;
cin>>n;
for(int i=;i<n;++i)
{
int t;
cin>>t;
a.push_back(t);
} int num;
cout<<" 请输入要选择的个数:"<<endl;
cin>>num;
Combine<int> c;
c.combine(a,,num);
return ;
}
执行过程:
第一次for也就是开始:beign=0,i=0,num=2;进入下一次递归也就是第二次for循环,beign=1,i=1,num=1;第三次递归时num==0,输出,本次递归结束。返回到第二次递归也就是第二次for循环,i自增1
在第二次for循环里面进行递归也就是第四次for循环(有点绕。。。),begin=1,i=2,num=1;第五次for循环时num==0,结束本次递归,退回到第二次for循环;i自增1,结果不符合for循环条件,第二次
for循环结束;以此推。。。(黑体加粗为同一层for循环)
排列组合算法(基于c++实现)的更多相关文章
- 排列组合算法(PHP)
		
用php实现的排列组合算法.使用递归算法,效率低,胜在简单易懂.可对付元素不多的情况. //从$input数组中取$m个数的组合算法 function comb($input, $m) { if($m ...
 - C#语法灵活运用之排列组合算法
		
今天群里有朋友求一个排列组合算法,题目是给定长度,输出所有指定字母的组合. 如指定字母a.b.c.d.e.f,长度为2,则结果应为:aa.ab.ac ... ef.ff. 有朋友给出算法,很有特色: ...
 - python实现高效率的排列组合算法-乾颐堂
		
组合算法 本程序的思路是开一个数组,其下标表示1到m个数,数组元素的值为1表示其下标 代表的数被选中,为0则没选中. 首先初始化,将数组前n个元素置1,表示第一个组合为前n个数. 然后从左到右扫描数组 ...
 - 排列组合算法的javascript实现
		
命题:从成员数为N的集合S中,选出M个元素,分别求其排列与组合结果集,即 A(N, M)与C(N, M) js解法: function queue(arr, size){ if(size > a ...
 - c语言中一种典型的排列组合算法
		
c语言中的全排列算法和组合数算法在实际问题中应用非常之广,但算法有许许多多,而我个人认为方法不必记太多,最好只记熟一种即可,一招鲜亦可吃遍天 全排列: #include<stdio.h> ...
 - 针对较大基数的排列组合算法Java实现类(n选m)
		
package com.utils; import java.math.BigDecimal; import java.math.RoundingMode; public class PLZUUtil ...
 - C(n,m)排列组合算法
		
主要解决C(n,m)问题 static class Extension { public static IList<IList<T>> GetGroup<T>(th ...
 - 排列组合算法的Java实现
		
转载于:http://cgs1999.iteye.com/blog/2327664
 - N个数组中所有元素的排列组合(笛卡尔积)算法
		
(1)N个数组对象中所有元素排列组合算法 private List<List<Object>> combineAlg(List<Object[]> nArray) ...
 
随机推荐
- 【知识总结】CSS中样式覆盖优先顺序
			
层叠样式类型 类型: 1. 浏览器默认样式 2. 浏览器用户自定义样式 3. 外部样式表 4. 内部样式表 5. 内联样式表 顺序: 浏览器默认样式 < 浏览器用户自定义样式 < 外部样式 ...
 - HDU4642
			
#include<stdio.h> #include<string.h> int main() { int i,j,n,m; int t; scanf("%d&quo ...
 - stm32_CAN总线知识(转)
			
源: stm32_CAN总线知识
 - 20145335郝昊《网络对抗》逆向及Bof基础实践
			
20145335郝昊<网络对抗>逆向及Bof基础实践 1.实践说明 本次实践是对一个名为pwn1的可执行Linux文件进行操作.程序的执行流程是:主函数main调用foo函数,foo将函数 ...
 - kylin构建cube优化
			
前言 下面通过对kylin构建cube流程的分析来介绍cube优化思路. 创建hive中间表 kylin会在cube构建的第一步先构建一张hive的中间表,该表关联了所有的事实表和维度表,也就是一张宽 ...
 - 从0开始配置ubuntu深度学习系统
			
目录 个性化配置 ubuntu安装及其分区 NVIDIA驱动安装 配置使用清华源 安装shadowsocks-qt 安装chrome 安装gdebi 安装atom 安装wps 安装sogou piny ...
 - taglist-plus 安装使用
			
taglist 可以查看文件中的 类,函数,变量等信息. 在.vimrc中添加: Plugin 'taglist-plus' 然后打开vim编辑器 PluginInstall 使用: 打开taglis ...
 - 【Jmeter】 Report Dashboard 生成html图形测试报告
			
背景 最近在学习Jmeter相关的东西,今天看了下Jmeter的官方文档,没想到在入门指南(Getting Started)第二条中就看到了让人惊喜的东西:可以利用既有测试数据生成HTML格式的Rep ...
 - HDU - 4812 D Tree 点分治
			
http://acm.hdu.edu.cn/showproblem.php?pid=4812 题意:有一棵树,每个点有一个权值要求找最小的一对点,路径上的乘积mod1e6+3为k 题解:点分治,挨个把 ...
 - 2-15-MySQL进阶
			
select select 字段列表 from 数据表 [[as] 别名] [where 条件] 别名: 数据表 [[as] 别名] select AA.money,BB.name from prod ...