穷举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;
            }

        }
    }
}
相关推荐
丁浩66624 分钟前
统计学---2.描述性统计-参数估计
人工智能·算法
sali-tec1 小时前
C# 基于halcon的视觉工作流-章54-N点标定
开发语言·图像处理·算法·计算机视觉·c#
娇娇yyyyyy1 小时前
C++11新特性基础知识点汇总
开发语言·c++·算法
不知名。。。。。。。。1 小时前
算法———栈
算法
烟花落o1 小时前
指针深入第二弹--字符指针、数组指针、函数指针、函数指针数组、转移表的理解加运用
c语言·开发语言·笔记·vscode·算法
蓝色汪洋1 小时前
数码和easy
算法
mit6.8242 小时前
[VT-Refine] 强化学习工作流 | 分布式-近端策略优化(DPPO)
分布式·算法
小二·2 小时前
深入解析 Rust 并行迭代器:Rayon 库的原理与高性能实践
开发语言·算法·rust