程序基本算法习题解析 给定n个字符{r1,r2,...,rn},要求生成n个字符的全排列。

要求输入一行字符串,输出所有排列。

思路:

可使用分治法(递归法)求解该题,步骤如下:

(设字符数组为A[n])选取数组A中的某个元素作为该数组的第一个数(交换位置),对剩下的元素进行全排列;在剩下的元素中,选取其中某个元素作为子字符数组的第一个数,对剩下的元素进行全排列,...,直到最后只剩一个元素,输出该数组。

例如有一个字符串为abcd,则将a、b、c、d分别作为第一个数,对剩下的字符进行全排列有a_ _ _,b_ _ _,c_ _ _,d_ _ _,再以a_ _ _组为例,对剩下的元素进行全排列,即ab_ _,ac_ _,ad_ _,再以ab_ _组为例,对剩下的元素进行全排列abc_,abd_,此时只剩最后一个元素,输出该数组,为abcd,abdc。其它组类似。

代码如下:

// Chapter13_1.cpp : Defines the entry point for the application.
// 给定n个字符{r1,r2,...,rn},要求生成n个字符的全排列
// 输入一行字符串,输出所有排列
#include "stdafx.h"
#include
#include
using namespace std;
//交换函数
void swap(char *a,char *b)
{
	char temp;
	temp = *a;
	*a = *b;
	*b = temp;
}
//求全排列函数
void fullPermutation(char *str, int begin, int n)
{
	//递归到最后一个字符时输出当前排列方式并返回
	if(begin == n-1)
	{
		for(int j=0;j> n;
	char *str = new char[n]; //字符数组
	cout << "输入字符串:" << endl;
	for(int i=0;i> str[i];
	cout << "全排列如下:" << endl;
	fullPermutation(str,0,n);
	delete [n]str;
	system("pause");
	return 0;
}

运行结果如下:

程序基本算法习题解析 给定n个字符{r1,r2,...,rn},要求生成n个字符的全排列。_第1张图片

程序基本算法习题解析 给定n个字符{r1,r2,...,rn},要求生成n个字符的全排列。_第2张图片

你可能感兴趣的:(程序基本算法习题解析)