【LeetCode刷题-回溯】-- 47.全排列II

47.全排列II

主要需要解决全排列不重复的问题,设定一个规则,保证在填第i个数的时候重复数字只会被填入一次即可,而在本题中,我们选择对原数组排序,保证相同的数字都相邻,然后每次填入的数一定是这个数所在重复数集合中「从左往右第一个未被填过的数字」

java 复制代码
class Solution {
    public List<List<Integer>> permuteUnique(int[] nums) {
        List<List<Integer>> res = new ArrayList<List<Integer>>();
        List<Integer> tmp = new ArrayList<Integer>();
        int n = nums.length;
        boolean[] visites = new boolean[n];
        Arrays.sort(nums);
        backtrack(res,tmp,visites,nums);
        return res;

    }
    public void backtrack(List<List<Integer>> res,List<Integer> tmp,boolean[] visites,int[] nums){
        if(tmp.size() == nums.length){
            res.add(new ArrayList(tmp));
            return;
        }
        for(int i = 0; i < nums.length; i++){ 
            //由于会有重复,保证在填第i个数的时候重复数组只会被填入一次即可
            //选择对原数字排序,保证相同的数字都相邻,然后每次填入的数一定是这个数所在重复数集合中从左往后第一个未被填过的数字
            //!visites[i-1]限制两个相邻的重复数字的访问顺序
            //比如[1,1,2]保证左边的1永远比右边的1先使用
            /* vis[i]:当前数字是否出现过
            * 如果当前数字与前一个数字相同(nums[i] == nums[i - 1]),
            * 并且前一个数字还没有出现的话(vis[i - 1] == false),
            * 那么就不能选择当前数字(continue),
            * 如果前面的数字已经出现过(vis[i] == true),则可以
            * 选择当前数字
            */
            if(visites[i] || ( i>0 && nums[i] == nums[i -1] && !visites[i-1]))
            {
                continue;
            }
            tmp.add(nums[i]);
            visites[i] = true;
            backtrack(res,tmp,visites,nums);
            tmp.remove(tmp.size()-1);
            visites[i]=false;
    
        }
    }
}
相关推荐
荼蘼1 小时前
基于 KNN 算法的手写数字识别项目实践
人工智能·算法·机器学习
Yuroo zhou1 小时前
IMU的精度对无人机姿态控制意味着什么?
单片机·嵌入式硬件·算法·无人机·嵌入式实时数据库
jackzhuoa2 小时前
java小白闯关记第一天(两个数相加)
java·算法·蓝桥杯·期末
Codeking__3 小时前
链表算法综合——重排链表
网络·算法·链表
minji...3 小时前
数据结构 堆(4)---TOP-K问题
java·数据结构·算法
技术卷4 小时前
详解力扣高频SQL50题之610. 判断三角形【简单】
sql·leetcode·oracle
AI_Keymaker4 小时前
一句话生成3D世界:腾讯开源混元3D模型
算法
Leon_vibs4 小时前
当 think 遇上 tool:深入解析 Agent 的规划之道
算法
旧时光巷4 小时前
【机器学习-2】 | 决策树算法基础/信息熵
算法·决策树·机器学习·id3算法·信息熵·c4.5算法
落了一地秋5 小时前
4.5 优化器中常见的梯度下降算法
人工智能·算法·机器学习