题目描述
输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。
基本的思路是:一个字符串的排列等于第一字符和后面剩余字符串排列的组合,对于含有N字符的字符串,组合中第一个字符串有N种可能,那么将所有的字符串轮流放在组合第一个当第一个字符,其余的N-1的字符串再计算其排列。因为这就是一个递归的过程。
C++代码
class Solution {
public:
vector<string> Permutation(string str)
{
vector<string> vec_str;
if(str.empty())
return vec_str;
Permutation1(str, 0, vec_str);
sort(vec_str.begin(),vec_str.end()); //注意最后还要排序
return vec_str;
}
/*
函数功能:对一个字符串计算其排列
函数参数: string str -- 待排列的字符串
int begin -- 当前原始字符串中当组合第一个字符的下标
vector<string>& vecStr -- 存储字符串的组合
*/
void Permutation1(string str, int begin, vector<string>& vecStr)
{
if(begin==(str.size()-1)) //遍历到了字符串结尾
{
vecStr.push_back(str);
return;
}
//这里的i从begin开始,相当于当前Permutation1函数只处理从begin之后的字符串
for(int i=begin;i<str.size();i++)
{
if(str[i]==str[begin]&&i!=begin) //去重
continue;
swap(str[i],str[begin]); //交换两个字符的位置
Permutation1(str, begin+1, vecStr);
swap(str[i],str[begin]); //当前位置处理后,交换回字符的位置
}
}
};
Java代码
链接:https://www.nowcoder.com/questionTerminal/fe6b651b66ae47d7acce78ffdd9a96c7
来源:牛客网
import java.util.List;
import java.util.Collections;
import java.util.ArrayList;
public class Solution {
public static void main(String[] args) {
Solution p = new Solution();
System.out.println(p.Permutation("abc").toString());
}
public ArrayList<String> Permutation(String str) {
List<String> res = new ArrayList<>();
if (str != null && str.length() > 0) {
PermutationHelper(str.toCharArray(), 0, res);
Collections.sort(res);
}
return (ArrayList)res;
}
public void PermutationHelper(char[] cs, int i, List<String> list) {
if (i == cs.length - 1) {
String val = String.valueOf(cs);
if (!list.contains(val))
list.add(val);
} else {
for (int j = i; j < cs.length; j++) {
swap(cs, i, j);
PermutationHelper(cs, i+1, list);
swap(cs, i, j);
}
}
}
public void swap(char[] cs, int i, int j) {
char temp = cs[i];
cs[i] = cs[j];
cs[j] = temp;
}
}