• 47. Permutations II 全排列可重复版本


    Given a collection of numbers that might contain duplicates, return all possible unique permutations.

    Example:

    Input: [1,1,2]
    Output:
    [
      [1,1,2],
      [1,2,1],
      [2,1,1]
    ]

    boolean数组不需要初始化,默认都是false

    
    

    重复的判断条件中,要加i > 0

    
    

    !used[i - 1],前一个元素还没用过 就找下一个元素了 不行

    class Solution {
        public List<List<Integer>> permuteUnique(int[] nums) {
        List<List<Integer>> list = new ArrayList<>();
        boolean[] used = new boolean[nums.length];
        Arrays.sort(nums);
        backtrack(nums, new ArrayList<>(), used, list);
        return list;
    }
    
    private void backtrack(int [] nums, List<Integer> tempList, boolean[] used, List<List<Integer>> list){
        if (tempList.size() == nums.length)
            list.add(new ArrayList<>(tempList));
        
            for(int i = 0; i < nums.length; i++){        
            if(used[i] || (i > 0 && (nums[i] == nums[i - 1] && !used[i - 1]))) 
                continue;
                
            tempList.add(nums[i]);
            used[i] = true;
            backtrack(nums, tempList, used, list);
            tempList.remove(tempList.size() - 1);
            used[i] = false;
        }
        
    } 
    }
    View Code
     
  • 相关阅读:
    jquery 异步请求Demo【转载】
    jQuery Ajax 实例 ($.ajax、$.post、$.get)【转载】
    Tomcat内存溢出详解【转载】
    安装和运行(含虚拟机)
    搭博客遇到的坑
    H5易企秀
    兼容和Error捕获
    小程序常用代码
    微信小程序是什么
    wx地址和腾讯地图
  • 原文地址:https://www.cnblogs.com/immiao0319/p/13206205.html
Copyright © 2020-2023  润新知