[100天算法】-全排列 II(day 51)

题目描述

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

示例:

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

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/permutations-ii
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

思路

复杂度分析

  • 时间复杂度:
  • 空间复杂度:

代码

JavaScript Code

复制代码
/**
 * @param {number[]} nums
 * @return {number[][]}
 */
var permuteUnique = function (nums) {
    const backtrack = (nums, path, res, visited) => {
        if (path.length === nums.length) {
            res.push(path);
            return;
        }

        for (let i = 0; i < nums.length; i++) {
            if (
                visited[i] ||
                (i > 0 && nums[i] === nums[i - 1] && visited[i - 1])
            )
                continue;
            visited[i] = true;
            path.push(nums[i]);
            backtrack(nums, [...path], res, visited);
            path.pop();
            visited[i] = false;
        }
    };

    const res = [];
    nums.sort((a, b) => a - b);
    backtrack(nums, [], res, Array(nums.length));
    return res;
};
相关推荐
飞天狗111几秒前
最小生成树算法
算法
H_老邪12 分钟前
贪心算法的应用
算法·ios·贪心算法
葳_人生_蕤14 分钟前
Hot100——739.每日温度
数据结构·算法
Elsa️74616 分钟前
洛谷p1046:用一个题练习排序+二分查找
c++·算法
木二_26 分钟前
056.Kubernetes cert-manager Root CA自签实战
算法·容器·kubernetes
老赵聊算法、大模型备案27 分钟前
网信办公示 2026 年 1-2 月生成式 AI 备案登记情况:新增 94 款,累计突破 1200 款
人工智能·算法·安全·aigc
x_xbx33 分钟前
LeetCode:21. 合并两个有序链表
算法·leetcode·链表
2501_9454235433 分钟前
C++与Rust交互编程
开发语言·c++·算法
我能坚持多久36 分钟前
【初阶数据结构10】——链式二叉树的功能实现
数据结构·算法
tankeven43 分钟前
HJ131 数独数组
c++·算法