题解 | 字符串的排列

字符串的排列

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保存已经出现过的字符。

全部评论

相关推荐

牛客246576843号:建议简历对点优化,想做HR专门列出HR实习,想做运营专门列出运营实习,并且对点写出项目经历以及数据,同时在个人总结上可以多凸出和岗位的匹配度
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务