力扣:47. 全排列 II

回溯解法思路:

1.先写一个集合来接收全部的全排列,再写一个集合来接受单个的全排列。在声明一个int【】数组来用于去重用的标记nums数组中什么元素用了的标记。同时排列一下nums数组方便去除重复的全排列。

2.调用回溯函数,终止条件为li2集合的长度等于nums.length,相当于遍历到了结尾,同时要注意相同的数字造成的重复的全排列,所以要去重。在遍历过程中假如Index【i】值为0就表示没有使用该nums【i】的值,使用的nums【i】值的Index【i】值为1。之后进行递归和回溯操作来遍历全部的全排列。

java 复制代码
class Solution {
    //接收全部的全排列
    List<List<Integer>> li1=new ArrayList<>();
    //接收单个全排列
    List<Integer> li2=new ArrayList<>();
    public List<List<Integer>> permuteUnique(int[] nums) {
        //用于去重用的标记nums数组中什么元素用了的标记
        int[] Index=new int[nums.length];
        //排列一下nums数组方便去除重复的全排列
        Arrays.sort(nums);
        //调用回溯函数
        huisu(nums,Index);
        return li1;
    }
    //回溯函数
    public void huisu(int[] nums,int[] Index){
        //终止条件
        if(li2.size()==nums.length){
            li1.add(new ArrayList<>(li2));
            return ;
        }
        //遍历全部的全排列
        for(int i=0;i<nums.length;i++){
            //去重相同的数字造成的重复的全排列
            if(i>0&&nums[i]==nums[i-1] && Index[i-1]==0){
                continue;
            }
        //假如Index【i】没有用,就进行向下寻找全排列
            if(Index[i]==0){
                //同时要把Index【i】标记为已使用
                Index[i]=1;
                //把元素添加到集合li2中
                li2.add(nums[i]);
                //递归继续寻找
                huisu(nums,Index);
                //回溯节点,寻找其他节点
                Index[i]=0;
                li2.removeLast();
            }
        }
    }
}
相关推荐
电子_咸鱼5 小时前
LeetCode——Hot 100【电话号码的字母组合】
数据结构·算法·leetcode·链表·职场和发展·贪心算法·深度优先
仰泳的熊猫5 小时前
LeetCode:785. 判断二分图
数据结构·c++·算法·leetcode
rit84324995 小时前
基于MATLAB实现基于距离的离群点检测算法
人工智能·算法·matlab
my rainy days7 小时前
C++:友元
开发语言·c++·算法
haoly19897 小时前
数据结构和算法篇-归并排序的两个视角-迭代和递归
数据结构·算法·归并排序
微笑尅乐7 小时前
中点为根——力扣108.讲有序数组转换为二叉搜索树
算法·leetcode·职场和发展
im_AMBER8 小时前
算法笔记 05
笔记·算法·哈希算法
夏鹏今天学习了吗8 小时前
【LeetCode热题100(46/100)】从前序与中序遍历序列构造二叉树
算法·leetcode·职场和发展
吃着火锅x唱着歌8 小时前
LeetCode 2389.和有限的最长子序列
算法·leetcode·职场和发展
嶔某8 小时前
二叉树的前中后序遍历(迭代)
算法