【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;
    
        }
    }
}
相关推荐
副露のmagic1 分钟前
更弱智的算法学习day 10
python·学习·算法
逸风尊者10 分钟前
开发可掌握的知识:uber H3网格
后端·算法
半问22 分钟前
付费投流硬控互联网
人工智能·算法·互联网·推荐·流量
西岸行者25 分钟前
学习Hammerstein-Wiener 模型,以及在回声消除场景中的应用
人工智能·学习·算法
夏乌_Wx40 分钟前
练题100天——DAY24:罗马数字转整数+环形链表+大小端判断
算法
youngee1140 分钟前
hot100-48腐烂的橘子
算法
liu****1 小时前
10.排序
c语言·开发语言·数据结构·c++·算法·排序算法
_OP_CHEN1 小时前
【算法基础篇】(三十二)动态规划之背包问题扩展:从多重到多维,解锁背包问题全场景
c++·算法·蓝桥杯·动态规划·背包问题·算法竞赛·acm/icpc
listhi5201 小时前
机械系统运动学与动力学在MATLAB及SimMechanics中的实现方案
人工智能·算法·matlab
fufu03111 小时前
Linux环境下的C语言编程(三十九)
c语言·数据结构·算法·链表