题解 | #字符串的排列#

字符串的排列

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

import java.util.*;
import java.io.*;
public class Solution {
    public ArrayList<String> Permutation(String str) {
        if (str == null) return null;
        char[] nums = str.toCharArray();
        ArrayList<String> list = new ArrayList<>();
        if (nums.length == 0) return list;
        dfs(0, nums, list);
        return list;
    }

    private void dfs(int idx, char[] nums, ArrayList<String> list) {
        // 不能再往下搜索
        if (idx == nums.length) {
            StringBuilder result = new StringBuilder();
            for (char value : nums) {
                result.append(value);
            }
            list.add(result.toString());
            return;
        }

        // 枚举这一层所有可以做出的选择
        Set<Character> set = new HashSet();
        for (int i = idx; i < nums.length; i++) {
            if(set.contains(nums[i])){
                continue;
            }
            set.add(nums[i]);
            swap(nums, idx, i);
            dfs(idx + 1, nums, list);
            swap(nums, idx, i);
        }
    }

    private void swap(char[] nums, int i, int j) {
        char tmp = nums[i];
        nums[i] = nums[j];
        nums[j] = tmp;
    }
}

解题思想:DFS标准模块,主要是 枚举这一层所有可以做出的选择

#算法##算法笔记#
全部评论

相关推荐

Yki_:你要算时间成本呀,研究生两三年,博士三四年,加起来就五六年了,如果你本科去腾讯干五年,多领五年的年薪,加上公司内涨薪,可能到时候十五年总薪资也跟博士差不多
点赞 评论 收藏
分享
05-19 15:21
已编辑
华南农业大学 Java
白火同学:你才沟通了200,说实话,北上广深杭这里面你连一座城市的互联网公司都没投满呢,更别说还有各种准一线二线城市了。等你沟通突破了三位数,还没结果再考虑转行的事吧。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务