排列组合算法(基于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) ...
随机推荐
- TED #07# How to inspire every child to be a lifelong reader
Alvin Irby: How to inspire every child to be a lifelong reader Prepare elementarykitchen tableforced ...
- Makefile解析(最简单的LED)
①led_sp.bin: start.o led.o #led_sp.bin是由 start.o 和 led.o 生成 ②arm-linux-ld -Ttext 0x0 -o led_sp.elf $ ...
- Python - TypeError: unicode argument expected, got 'str'
参考:TypeError: unicode argument expected, got 'str' Python代码: from io import StringIO def main(): f = ...
- 比较两个JSON字符串是否完全相等
RT,比较两个JSON字符串是否完全相等,这里使用google贡献的Gson. 一,no POJO,即不另外创建一个简单Java类 [java] view plain copy String str1 ...
- 山东省第四届ACM程序设计竞赛部分题解
A : Rescue The Princess 题意: 给你平面上的两个点A,B,求点C使得A,B,C逆时针成等边三角形. 思路: http://www.cnblogs.com/E-star/arch ...
- $.proxy用法详解
jQuery中的$.proxy官方描述为: 描述:接受一个函数,然后返回一个新函数,并且这个新函数始终保持了特定的上下文语境. 官方API: jQuery.proxy( function, conte ...
- domain---Node.js 异步异常的处理与domain模块解析
var domain = require('domain'); app.use(function (req, res, next) { var reqDomain = domain.create(); ...
- 定义集合属性(WPF)
在wpf中,定义集合属性时,字段可以使用“ObservableCollection<T>”定义,以保证数据改变时的自动通知功能:属性可以使用“ICollection”定义,保证属性的灵活性 ...
- PistgreSQL9.6手册(基础摘录)
学习目的:基础使用. 能够开发RoR就行. git: https://github.com/postgres-cn/pgdoc-cn 1.2. 架构基础 PostgreSQL使用一种客户端/服务器的模 ...
- Manacher练习
看这篇博客学了下Manacher, 讲的很好, 但他的板子写错了.. https://www.cnblogs.com/Lyush/p/3221503.html 练习1 hdu 3068最长回文 板子题 ...