码迷,mamicode.com
首页 > 编程语言 > 详细

C语言 全排列

时间:2015-06-03 17:44:26      阅读:143      评论: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
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!