【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;
    
        }
    }
}
相关推荐
久菜盒子工作室20 分钟前
量化金融|基于算法和模型的预测研究综述
算法·金融
CoovallyAIHub1 小时前
SBP-YOLO:面向嵌入式悬架的轻量实时模型,实现减速带与坑洼高精度检测
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
医药、零件、饮料瓶盖……SuperSimpleNet让质检“即插即用”
深度学习·算法·计算机视觉
dragoooon341 小时前
[优选算法专题二滑动窗口——串联所有单词的子串]
数据结构·c++·学习·算法·leetcode·学习方法
刃神太酷啦1 小时前
C++ 异常处理机制:从基础到实践的全面解析----《Hello C++ Wrold!》(20)--(C/C++)
java·c语言·开发语言·c++·qt·算法·leetcode
Brookty2 小时前
【算法】双指针(二)复写零
学习·算法
胖达不服输2 小时前
「日拱一码」081 机器学习——梯度增强特征选择GBFS
人工智能·python·算法·机器学习·梯度增强特征选择·gbfs
初级炼丹师(爱说实话版)3 小时前
2025算法八股——深度学习——优化器小结
人工智能·深度学习·算法
努力的小帅3 小时前
C++_哈希
开发语言·c++·学习·算法·哈希算法·散列表
Christo33 小时前
TFS-2023《Fuzzy Clustering With Knowledge Extraction and Granulation》
人工智能·算法·机器学习·支持向量机