题目描述:
输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。
输入描述:
输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母。
本题知识点:
字符串 动态规划 递归
解题思路:
根据题意可知,需要将输入的字符串中所有字符进行排列,并去除重复字符串即可。
通过递归方法,先固定一个字符,求剩下字符串的所有排列,然后再将第一个字符与后面的所有字符依次交换,求剩下字符串的所有排列。
还可以使用C++STL的next_permutation函数枚举所有的排列方式。
代码:
1.
class Solution {
public:
vector<string> Permutation(string str)
{
vector<string> result;
if(str.empty()) return result;
Permutation(str,result,0);
sort(result.begin(),result.end());
return result;
}
void Permutation(string str,vector<string> &result,int begin)
{
if(begin == str.size()-1)
{
if(find(result.begin(),result.end(),str) == result.end())
result.push_back(str);
}
else
{
for(int i=begin;i<str.size();++i)
{
swap(str[i],str[begin]);
Permutation(str,result,begin+1);
swap(str[i],str[begin]);
}
}
}
void swap(char &fir,char &sec)
{
char temp = fir;
fir = sec;
sec = temp;
}
};
2.
class Solution {
public:
vector<string> Permutation(string str) {
int length = str.size();
vector<string> result;
if(length == 0)
return result;
do{
result.push_back(str);
} while(next_permutation(str.begin(), str.end()));
return result;
}
};