利用递归实现全排列
2017-04-06 00:46
218 查看
递归算法通过穷举实现全排列
#include<stdio.h>
void swap(int *p, int i, int j)
{
int temp=0;
temp = p[i];
p[i] = p[j];
p[j] = temp;
}
void comb(int *p,int length,int N)
{
int *p2 = p,k=length-1;
if (length==1)
{
for (int i = 0; i <=N-1; i++)
{
printf("%d ", p[i]);
}
printf("\n");
cunt++;
}
else
{
for (int i=0;i<length;i++)
{
swap(p2, i,k );
comb(p2,length-1,N);
swap(p2, k, i);
}
}
}
//static int cunt = 0;
int main()
{
int N;
int a[10] = { 1, 2, 3, 4 ,5,6,7,8,9,10};
N=10;
comb(a, 10,N);
printf("%d\n", cunt);
return 0;
}
#include<stdio.h>
void swap(int *p, int i, int j)
{
int temp=0;
temp = p[i];
p[i] = p[j];
p[j] = temp;
}
void comb(int *p,int length,int N)
{
int *p2 = p,k=length-1;
if (length==1)
{
for (int i = 0; i <=N-1; i++)
{
printf("%d ", p[i]);
}
printf("\n");
cunt++;
}
else
{
for (int i=0;i<length;i++)
{
swap(p2, i,k );
comb(p2,length-1,N);
swap(p2, k, i);
}
}
}
//static int cunt = 0;
int main()
{
int N;
int a[10] = { 1, 2, 3, 4 ,5,6,7,8,9,10};
N=10;
comb(a, 10,N);
printf("%d\n", cunt);
return 0;
}
相关文章推荐
- python 利用递归实现全排列
- 利用递归实现全排列
- 全排列的递归实现以及利用STL实现全排列
- 递归实现全排列
- C++全排列递归实现
- 利用SQL SERVER 2005 中的CTE 实现树的递归
- 利用递归实现不定重数多重循环
- 非递归实现不重复序列的全排列(三)
- 利用CTE递归在存储过程中实现真分页
- 全排列的递归实现
- 利用递归轻松实现TreeView控件中子节点的全选操作[VB]
- 算法——全排列递归实现
- 非递归实现不重复序列的全排列(一)
- 利用递归实现不定重数多重循环(附源代码)
- 利用递归实现栈的逆转(转何海涛)
- 简单全排列C递归实现 没考虑重复情况
- 非递归实现不重复序列的全排列(三)
- 非递归实现不重复序列的全排列(二)
- 输出一个数全排列的组合【利用哈密尔顿图遍历算法实现】
- 汉诺塔、反向输出问题--利用递归实现