题目描述
输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则按字典序打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。
输入描述:
输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母。
示例1
输入
"ab"
返回值
["ab","ba"]
class Solution {
public:
vector<string> res;
vector<string> Permutation(string str) {
if(str.size() == 0)
{
return res;
}
PermutationCore(str, 0);
return res;
}
void PermutationCore(string str, int begin)
{
if(begin == str.size()-1)
{
res.push_back(str);
return;
}
else
{
for(int i=begin; i<str.size(); i++)
{
if(i>begin && str[i]==str[begin])
{
continue;
}
swap(str[i], str[begin]);
PermutationCore(str, begin+1);
}
}
}
};