题解 | #字符串的排列#

字符串的排列

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

主要思想:

-通过回溯法将字符串中的字符排列都排列出来,但是可能会有重复的排列

-利用Set去重

import java.util.*;
public class Solution {
    ArrayList<String> result = new ArrayList<>();
    StringBuilder sb = new StringBuilder();
    public ArrayList<String> Permutation(String str) {
        // 标记数组
        boolean[] used = new boolean[str.length()];
        backTrack(str, used);
      	// 利用Set去重
        Set<String> set = new HashSet<>(result);
        ArrayList<String> res = new ArrayList<>();
        for(String s : set) {
            res.add(s);
        }
        return res;
    }
    public void backTrack(String str, boolean[] used) {
        if(sb.length() == str.length()) {
            result.add(sb.toString());
            return;
        }
        for(int i = 0; i < str.length(); i++) {
            char c = str.charAt(i);
            if(used[i] == false) {
                used[i] = true;
                sb.append(c);
                backTrack(str, used);
                sb.deleteCharAt(sb.length() - 1);
                used[i] = false;
            }
            
        }
    }
    
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
11-21 17:16
科大讯飞 算法工程师 28.0k*14.0, 百分之三十是绩效,惯例只发0.9
点赞 评论 收藏
分享
头像
10-16 09:58
已编辑
门头沟学院 Java
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务