题解 | 字符串的排列

字符串的排列

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

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param str string字符串 
     * @return string字符串ArrayList
     */
    ArrayList<String> ans = new ArrayList<>();
    StringBuffer path = new StringBuffer();
    boolean[] used;
    public ArrayList<String> Permutation (String str) {
        // write code here
        if(str.length() < 2){
            ans.add(str);
            return ans;
        }
        used = new boolean[str.length()];
        back_tracking(str);

        return ans;
    }
    public void back_tracking(String str){
        if(path.length() == str.length()){
            ans.add(path.toString());
        }
        ArrayList<Character> chosed = new ArrayList<>();
        for(int i = 0; i < str.length(); i++){
            if(!used[i] && (chosed.isEmpty() || !chosed.contains(str.charAt(i)))){
                chosed.add(str.charAt(i));
                used[i] = true;
                path.append(str.charAt(i));
                back_tracking(str);
                path.deleteCharAt(path.length() - 1);
                used[i] = false;
            }
        }
    }
}

用一个list保存已经出现过的字符。

全部评论

相关推荐

牛客ID:561366855:期望薪资多少?难以相信这简历找不到工作。说明二本电子信息专业想对口就业非常难。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务