标签:block 打印 大小写 pre lse new substring i++ 字典序
输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。(输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母。)
对字符串所有字符的全排列,只要注意一下重复的排列就可以了
import java.util.ArrayList;
public class Solution {
private int length = 0;
public ArrayList<String> Permutation(String str) {
length = str.length();
return per(str);
}
private ArrayList<String> per(String str) {
ArrayList<String> list = new ArrayList<>();
if (str.length() == 1) {
list.add(str);
}
else {
for (int i=0; i<str.length(); i++) {
String subStr = str.substring(0, i) + str.substring(i+1, str.length());
ArrayList<String> subList = per(subStr);
for (String s : subList) {
String newStr = str.substring(i,i+1) + s;
if (newStr.length() == length && list.contains(newStr))
continue;
list.add(newStr);
}
}
}
return list;
}
}
标签:block 打印 大小写 pre lse new substring i++ 字典序
原文地址:https://www.cnblogs.com/yi-hui/p/8997993.html