首页 > 编程语言 > 详细

C语言 全排列

时间:2015-06-03 17:43:58      阅读:224      评论:0      收藏:0      [点我收藏+]
#include<stdio.h>
#include<stdlib.h>
#include<vector>

void swap(int *a,int *b)
{
	int tmp;
	tmp=*a;
	*a=*b;
	*b=tmp;
}

void permutation(int nums[],int i,int n)
{
	int j=0;
	if(i==n)
	{
		for(j=0;j<n;j++)
			printf("%d ",nums[j]);
		printf("\n");
	}
	else
	{
		for(j=i;j<n;j++)
		{
			swap(&nums[i],&nums[j]);
			permutation(nums,i+1,n);
			swap(&nums[i],&nums[j]);
		}
	}
}

int main()
{
	int n;
	while(scanf("%d",&n)!=EOF)
	{
		int i;
		int *nums=(int *)malloc(sizeof(int)*n);
		for(i=0;i<n;i++)
			scanf("%d",&nums[i]);
		permutation(nums,0,n);
	}
	return 0;
}

C语言 全排列

原文:http://blog.csdn.net/zyh920521/article/details/46347475

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!