黑马程序员技术交流社区

标题: 如何打印字符串的所有排列组合?急,求大神 [打印本页]

作者: 足球骑士szw    时间: 2016-10-9 00:10
标题: 如何打印字符串的所有排列组合?急,求大神
分析以下需求,并用代码实现:
        (1)打印一个字符串的全字符组合情况,原始字符串中没有重复字符
        (2)例如:原始字符串是"def", 打印得到下列所有组合情况:
                "d" "e" "f" "de" "df" "ed" "ef" "fd" "fe" "def" "dfe" "edf" "efd" "fde" "fed"
强调一下,原始字符串的长度时不确定的,不是就三个啊

作者: 足球骑士szw    时间: 2016-10-9 00:11
求大神解答....
作者: yanghaozhang    时间: 2016-10-9 00:12
这是一题点招题吧,同问哈,先Mark
作者: HackSon    时间: 2016-10-9 19:47
我做出来了,但是不知道语言上怎么表达你才能听得清楚,如果你要的话我就发给你,但是我不保证你看的懂,因为每个人的思路不一样
作者: wolfking0608    时间: 2016-10-9 23:30
/*分析以下需求,并用代码实现:
(1)打印一个字符串的全字符组合情况,原始字符串中没有重复字符
(2)例如:原始字符串是"def", 打印得到下列所有组合情况:
"d" "e" "f" "de" "df" "ed" "ef" "fd" "fe" "def" "dfe" "edf" "efd" "fde" "fed"
     原始字符串的长度时不确定的
* */
public class 非固定字符串组合 {
        static ArrayList<String> ts = new ArrayList<>();
        public static void main(String[] args) {
                 TreeSet<String> list = new TreeSet<>(new Comparator<String>() {
                       
                        @Override
                        public int compare(String p1, String p2) {
                                int num =p1.length()-p2.length();
                                return num==0?1:num;
                        }
                });
                Scanner sc = new Scanner(System.in);
                System.out.println("请输入字符串!!!");
                String str = sc.nextLine();
           mysort(str,"");
           //下一步开始去重
          
           for (String string : ts) {
                  char[] arr = string.toCharArray();
                  String st ="";
                  for (int i = 0; i < arr.length; i++) {
                          if(!st.contains(arr[i]+"")){
                                  st+=arr[i];
                                  if(i==arr.length-1){
                                         list.add(string);
                                  }
                          }else{
                                  break;
                          }
                }
        }
                for (String string : list) {
                        System.out.println(string);
                }
               
               
        }
        /*参数列表 第一个是原来的字符串, 第二个是上一个字符串
         * */
        public static void mysort(String str,String stt){
               
                char[] arr = str.toCharArray();
                for (int i = 0; i <arr.length; i++) {
                        if(stt.length()==str.length()){
                                return ;
                        }
                        String st = stt+arr[i];
                        //System.out.println(st);
                        ts.add(st);
                        mysort(str,st);
                       
                }
               
        }
}
//我做出来了,可以给点黑马币吗?这个题我想了挺长时间的!!!




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2