[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;
};
相关推荐
AI爱好者20207 小时前
智能优化算法2025年新书推荐——《智能优化算法及其MATLAB实例(第4版)》
开发语言·算法·matlab
LYFlied7 小时前
【每日算法】LeetCode215. 数组中的第K个最大元素
前端·算法
炽烈小老头7 小时前
【每天学习一点算法 2026/01/06】最小栈
学习·算法·leetcode
mit6.8247 小时前
hadoop|贪心
算法
2501_941805317 小时前
在阿姆斯特丹智能港口场景中构建集装箱实时调度与高并发物流数据分析平台的工程设计实践经验分享
java·大数据·算法
涂山小楼7 小时前
线程join()方法的深度理解
java·前端·算法
gihigo19988 小时前
LDPC码硬判决译码算法的详细解析
网络·算法
Clarence Liu8 小时前
快慢指针问题
后端·算法
Swift社区8 小时前
LeetCode 467 环绕字符串中唯一的子字符串
算法·leetcode·职场和发展
Yzzz-F8 小时前
P3870 [TJOI2009] 开关[线段树(区间加 区间和 变种)]
算法