剑指:字符串的排列

字符串的排列

http://www.nowcoder.com/questionTerminal/fe6b651b66ae47d7acce78ffdd9a96c7

题目描述

输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。


思路:就是回溯。本来没想到用set,自己想了半天(去lt也刷了,lt样例多写,不通过的可以试aab这个样例),最后发现还要有序。。。。。果断treeset了。

代码:

import java.util.ArrayList;
import java.util.Set;
import java.util.TreeSet;
public class Solution {
    public ArrayList<String> Permutation(String str) {
        Set<String> set=new TreeSet<>();
           if(str.length()<1)
               return new ArrayList<String>(set);
           Find(str,0,set);
           return new ArrayList<String>(set);
    }
    
    private  void Find(String str, int f, Set<String> set) {
        if (f == str.length() - 1) {
            set.add(str);
           }else {
               for(int i=f;i<str.length();i++) {
                   char []cs = new char[str.length()];
                   char s1;
                   cs=str.toCharArray();
                   s1=cs[i];//交换字母
                   cs[i]=cs[f];
                   cs[f]=s1;    
                   Find(String.valueOf(cs), f+1,set);
                   s1=cs[i];//回溯
                   cs[i]=cs[f];
                   cs[f]=s1;                                            
               }
           }    
    }
}
全部评论

相关推荐

11-08 17:36
诺瓦科技_HR
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务