穷举vs暴搜vs深搜vs回溯vs剪枝专题一>全排列II

题目:


解析:

这题设计递归函数,主要把看如何剪枝


代码:

java 复制代码
class Solution {
    private List<List<Integer>> ret;
    private List<Integer> path;
    private boolean[] check;
    public List<List<Integer>> permuteUnique(int[] nums) {
        ret = new ArrayList<>();
        path = new ArrayList<>();
        check = new boolean[nums.length];
        Arrays.sort(nums);//

        dfs(nums,0);
        return ret;
    }

    //pos是决策树层数
    private void dfs(int[] nums,int pos){
        if(pos == nums.length){
            ret.add(new ArrayList<>(path));
            return;
        }

        for(int i = 0; i < nums.length; i++){ 
            
            //不合法分支剪枝
            if(check[i] == true || i != 0 && nums[i] == nums[i-1] && check[i-1] == false)
                continue;

            if(check[i] == false){
            path.add(nums[i]);
            check[i] = true;
            dfs(nums,pos+1);

            //恢复现场
            path.remove(path.size()-1);
            check[i] = false;
            }

        }
    }
}
相关推荐
地平线开发者4 小时前
征程 6 | cgroup sample
算法·自动驾驶
姓蔡小朋友5 小时前
算法-滑动窗口
算法
君义_noip5 小时前
信息学奥赛一本通 2134:【25CSPS提高组】道路修复 | 洛谷 P14362 [CSP-S 2025] 道路修复
c++·算法·图论·信息学奥赛·csp-s
kaikaile19956 小时前
基于拥挤距离的多目标粒子群优化算法(MO-PSO-CD)详解
数据结构·算法
不忘不弃6 小时前
求两组数的平均值
数据结构·算法
leaves falling6 小时前
迭代实现 斐波那契数列
数据结构·算法
珂朵莉MM6 小时前
全球校园人工智能算法精英大赛-产业命题赛-算法巅峰赛 2025年度画像
java·人工智能·算法·机器人
Morwit6 小时前
*【力扣hot100】 647. 回文子串
c++·算法·leetcode
tobias.b6 小时前
408真题解析-2009-13-计组-浮点数加减运算
算法·计算机考研·408考研·408真题