47. 全排列 II

题目

给定一个可包含重复数字的序列 nums按任意顺序 返回所有不重复的全排列。

示例 1:

复制代码
输入:nums = [1,1,2]
输出:
[[1,1,2],
 [1,2,1],
 [2,1,1]]

示例 2:

复制代码
输入:nums = [1,2,3]
输出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]

提示:

  • 1 <= nums.length <= 8
  • -10 <= nums[i] <= 10

思路

为了得到不重复的所有排列组合,我们对输入数组进行排序,让相同的元素相邻排列,这样在后续的回溯过程中,能更方便地判断和避免重复排列。然后创建一个标记数组visit,看这个数字是否已被使用,保证每个元素在一个排列中仅使用一次。在hs中,将未使用的元素添加到当前排列中,然后在检查元素是否已被使用,还会检查当前元素是否和前一个元素相同,并且前一个元素未被使用。如果满足这个条件,就跳过当前元素,避免生成重复排列。在递归调用结束后,将元素标记为未使用,并从当前排列中移除该元素,这样就可以尝试其他可能的排列。

代码

cpp 复制代码
class Solution {
public:
    vector<int> visit;//用来标记访问过的数
    void hs(vector<int>& nums,vector<vector<int>>& res,int index,vector<int>& n)
    {
        if (index==nums.size())//n里面已经把nums里所有的数字都填充进来了
        {
            res.emplace_back(n);
            return;
        }
        for(int i=0;i<nums.size();i++) {
            //当前数字已被访问过或当前数字与前一个数字大小相等并且前一个数字未被访问
            if (visit[i]||(i>0&&nums[i]==nums[i-1]&&!visit[i - 1]))
            {
                continue;//跳过当前循环,进入下一层
            }
            n.emplace_back(nums[i]);//符合条件,放入n
            visit[i]=1;//把当前数字标记为已访问
            hs(nums,res,index+1,n);//从下一个数开始进行递归
            visit[i] = 0;//把当前数字标记为未访问并从n中移除,尝试其他排列
            n.pop_back();
        }
    }
    vector<vector<int>> permuteUnique(vector<int>& nums) {
        vector<vector<int>> res;//结果数组
        vector<int> n;//存每种组合的数组
        visit.resize(nums.size());//把visit数组的大小调整成nums数组的大小
        sort(nums.begin(),nums.end());//对nums排序,方便把重复的数字放在一起
        hs(nums,res,0,n);//递归进行全排列
        return res;
    }
};
相关推荐
达文汐1 分钟前
【困难】力扣算法题解析LeetCode332:重新安排行程
java·数据结构·经验分享·算法·leetcode·力扣
一匹电信狗1 分钟前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl
User_芊芊君子1 分钟前
【LeetCode经典题解】搞定二叉树最近公共祖先:递归法+栈存路径法,附代码实现
算法·leetcode·职场和发展
培风图南以星河揽胜2 分钟前
Java版LeetCode热题100之零钱兑换:动态规划经典问题深度解析
java·leetcode·动态规划
算法_小学生3 分钟前
LeetCode 热题 100(分享最简单易懂的Python代码!)
python·算法·leetcode
执着2593 分钟前
力扣hot100 - 234、回文链表
算法·leetcode·链表
Gorgous—l4 分钟前
数据结构算法学习:LeetCode热题100-多维动态规划篇(不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离)
数据结构·学习·算法
熬夜造bug5 分钟前
LeetCode Hot100 刷题路线(Python版)
算法·leetcode·职场和发展
2401_8384725127 分钟前
C++中的访问者模式
开发语言·c++·算法
老鼠只爱大米33 分钟前
LeetCode经典算法面试题 #108:将有序数组转换为二叉搜索树(递归分治、迭代法等多种实现方案详解)
算法·leetcode·二叉树·二叉搜索树·平衡树·分治法