zoukankan      html  css  js  c++  java
  • 47. 全排列 II

    题目描述:

      给定一个可包含重复数字的序列,返回所有不重复的全排列。

      示例:

        输入: [1,1,2]
        输出:
          [
            [1,1,2],
            [1,2,1],
            [2,1,1]
          ]

    题解:

    class Solution {
        public List<List<Integer>> permuteUnique(int[] nums) {
           List<Integer> list = new ArrayList<>();
            //以下的操作需要保证顺序性
            Arrays.sort(nums);
            for(int index =0;index<nums.length;index++){
                list.add(nums[index]);
            }
            List<List<Integer>> resList = new ArrayList<>();
            backList(list,resList,new Stack<>(),nums.length);
            return resList;
        }
    
        public static void backList(List<Integer> list, List<List<Integer>> resList, Stack<Integer> res, Integer in){
            if(res.size() == in){
                resList.add(new ArrayList<>(res));
                return;
            }
            for(int li=0;li<list.size();li++ ){
                //对于重复元素,大概就是如此解决,大于起始元素
                if(li>0 && list.get(li) == list.get(li-1)){continue;}
                res.push(list.get(li));
                //相当于状态重置的作用。或者使用一个列表用来表示哪些数据已经使用
                List temp = new ArrayList<>(list);
                temp.remove(list.get(li));
                backList(temp,resList,res,in);
                temp = null;
                res.pop();
    
            }
        }
    }    
  • 相关阅读:
    中国大概可用NTPserver地址
    ROOT android 原则。 基于(zergRush)
    Struts2他们拦截器实例定义—登陆权限验证
    引用与指针
    address_space 从哪里来
    C++ 可以多个函数声明
    linux下远程管理利器-tmux
    内核空间和用户空间的分界 PAGE_OFFSET
    io端口
    C中程序的内存分配
  • 原文地址:https://www.cnblogs.com/mayang2465/p/11927018.html
Copyright © 2011-2022 走看看