生成排列和组合

原创 2012年03月30日 19:21:51

1 . 无重复元素的全排列

当然stl有next_permutation()函数,用起来更方便

#include<cstdio>
#include<string>
using namespace std;
int n,a[100],count;
void permutation(int k){
	if(k==n){
		for(int i=1;i<=n;i++)
			printf("%d ",a[i]);
		printf("\n");
		count++;
		return;
	}
	for(int i=k;i<=n;i++){
		int tem=a[k];
		a[k]=a[i];
		a[i]=tem;
		permutation(k+1);
		tem=a[k];
		a[k]=a[i];
		a[i]=tem;
	}
}
int main(){
	while(scanf("%d",&n)!=EOF){
		for(int i=1;i<=n;i++)
			a[i]=i;
			//scanf("%d",&a[i]);
		count=0;
		permutation(1);
		printf("There is %d permutatiomns\n",count);
	}
}

2 . 有重复元素的全排列

 

#include<cstdio>
#include<string>
#include<map>
using namespace std;
int n,m,seq[100],sum[100],count,out[100];          //n表示输入字符数,m表示不重复字符数
void permutation(int k){
	if(k==n+1){
		for(int i=1;i<=n;i++)
			printf("%d ",out[i]);
		printf("\n");
		count++;
		return;
	}
	for(int i=1;i<=m;i++)
		if(sum[i]){
			sum[i]--;
			out[k]=seq[i];
			permutation(k+1);
			sum[i]++;
		}
}
int main(){
	int tem;
	while(scanf("%d",&n)!=EOF){
		map<int,int>ma;
		m=0;
		memset(sum,0,sizeof(sum));
		for(int i=1;i<=n;i++){
			scanf("%d",&tem);
			if(ma[tem]!=0)
				sum[ma[tem]]++;
			else{
				seq[++m]=tem;
				sum[m]=1;
				ma[tem]=m;
			}
		}
		count=0;
		permutation(1);
		printf("There is %d permutatiomns\n",count);
	}
}


 3 . 有重复元素的组合

#include<cstdio>
#include<string>
#include<map>
using namespace std;
int n,k,m,seq[100],sum[100],count,out[100];          //n表示输入字符数,m表示不重复字符数
void combination(int now,int p){
	if(now==k+1){
		for(int i=1;i<=k;i++)
			printf("%d ",out[i]);
		printf("\n");
		count++;
		return;
	}
	for(int i=p;i<=m;i++)
		if(sum[i]){
			sum[i]--;
			out[now]=seq[i];
			combination(now+1,i);
			sum[i]++;
		}
}
int main(){
	int tem;
	while(scanf("%d %d",&n,&k)!=EOF){
		map<int,int>ma;
		m=0;
		memset(sum,0,sizeof(sum));
		for(int i=1;i<=n;i++){
			scanf("%d",&tem);
			if(ma[tem]!=0)
				sum[ma[tem]]++;
			else{
				seq[++m]=tem;
				sum[m]=1;
				ma[tem]=m;
			}
		}
		count=0;
		combination(1,1);
		printf("There is %d combinations\n",count);
	}
}


 4 . 有重复元素的全组合

#include<cstdio>
#include<string>
#include<map>
using namespace std;
int n,k,m,seq[100],sum[100],count,out[100];          //n表示输入字符数,m表示不重复字符数
void combination(int now,int p){
	if(now>1){
		for(int i=1;i<now;i++)
			printf("%d ",out[i]);
		printf("\n");
		count++;
	}
	for(int i=p;i<=m;i++)
		if(sum[i]){
			sum[i]--;
			out[now]=seq[i];
			combination(now+1,i);
			sum[i]++;
		}
}
int main(){
	int tem;
	while(scanf("%d",&n)!=EOF){
		map<int,int>ma;
		m=0;
		memset(sum,0,sizeof(sum));
		for(int i=1;i<=n;i++){
			scanf("%d",&tem);
			if(ma[tem]!=0)
				sum[ma[tem]]++;
			else{
				seq[++m]=tem;
				sum[m]=1;
				ma[tem]=m;
			}
		}
		count=0;
		combination(1,1);
		printf("There is %d combinations\n",count);
	}
}


 

 

 

组合数学中的全排列生成算法

  • 2009年10月22日 00:12
  • 124KB
  • 下载

随机数与排列组合:生成1亿个随机的不同16位数

。。。。。。。。。。。。。。

Android 用ffmpeg生成Gif 各种排列组合的性能测试结果

Gif 测试 bmps -> Animated gif encode   -> 质量不错,  慢死,   10帧大概要两分钟 bmps 》 png  》avi 》gif    保存...

生成组合和排列方法总结

zhourongqing 生成组合和排列 方法一:递归求解 (1)、从 n 个元素中,选择 m 个元素的组合 #include using name...

组合优化中的全排列生成方法

组合优化中的全排列生成之前有同学遇到组合优化(如0-1优化)问题,想采用穷举法,那么首先就要穷举产生所有的组合。以0-1优化为例,假设当前有3个item,每个item有“选”或“不选”两种状态。...

【算法】组合数学——排列数生成算法详解(一)

组合数学中的全排列生成算法历来是组合数学考试的重要考察点,因此在这里我简单的介绍一下6种全排列生成算法的详细过程,并借此比较它们之间的优劣之处。 不论是哪种全排列生成算法,都遵循着“原排...

dfs生成排列组合模板

枚举可重复排列的模板 [cpp] view plain copy   #include   using namespace std;   int n,...

生成组合和排列

方法一:递归求解 (1)、从 n 个元素中,选择 m 个元素的组合 复制代码 #include using namespace std; int ans[10],a[20],m,n; bo...

递归的思想生成排列组合

#include #include #include #include #include using namespace std; int m,n,a[10]; bool vis[10]; int a...

组合数学——排列数生成算法详解(zz)

组合数学中的全排列深成算法历来是组合数学考试的重要考察点,因此在这里我简单的介绍一下6种全排列生成算法的详细过程,并借此比较它们之间的优劣之处。 不论是哪种全排列生成算法,都遵循着“原排列”→“原中介...
  • ZCSYLJ
  • ZCSYLJ
  • 2011年07月24日 15:29
  • 1633
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:生成排列和组合
举报原因:
原因补充:

(最多只允许输入30个字)