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();
    
            }
        }
    }    
  • 相关阅读:
    第 13 章 外观模式
    第 12 章 桥接模式
    第 10 章 适配器模式
    第 7 章 原型模式
    PHP的预处理语句的使用
    PHP的异常处理
    PHP中PDO函数的使用
    PHP的PDO模式数据操作
    PHP的 Final关键字、类(文件)的加载和命名空间
    PHP的魔术常量和魔术方法
  • 原文地址:https://www.cnblogs.com/mayang2465/p/11927018.html
Copyright © 2011-2022 走看看