程序基本算法习题解析 给定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<iostream>
#include<string>
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;j++)
		{
			cout << str[j];
		}
		cout << endl;
		return;
	}
	else
	{
		//对后面的字符进行全排列
		for(int i=begin;i<n;i++)
		{
			//将子字符串的每个字符都调换到最前面一次
			swap(&str[begin],&str[i]);	
			//对子字符串的子字符串进行全排列计算
			fullPermutation(str,begin+1,n);
			//调换回来
			swap(&str[begin],&str[i]);
		}
		return;
	}
}
int main()
{
	int n; //n:字符个数
	cout << "输入字符个数:";
	cin >> n;
	char *str = new char[n]; //字符数组
	cout << "输入字符串:" << endl;
	for(int i=0;i<n;i++)
		cin >> str[i];
	cout << "全排列如下:" << endl;
	fullPermutation(str,0,n);
	delete [n]str;
	system("pause");
	return 0;
}

运行结果如下:

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值