[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;
};
相关推荐
Gorgous—l21 小时前
数据结构算法学习:LeetCode热题100-动态规划篇(下)(单词拆分、最长递增子序列、乘积最大子数组、分割等和子集、最长有效括号)
数据结构·学习·算法
北京地铁1号线1 天前
2.3 相似度算法详解:Cosine Similarity 与 Euclidean Distance
算法·余弦相似度
Remember_9931 天前
【LeetCode精选算法】滑动窗口专题一
java·数据结构·算法·leetcode·哈希算法
小饼干超人1 天前
详解向量数据库中的PQ算法(Product Quantization)
人工智能·算法·机器学习
你撅嘴真丑1 天前
第四章 函数与递归
算法·uva
漫随流水1 天前
leetcode回溯算法(77.组合)
数据结构·算法·leetcode·回溯算法
玄冥剑尊1 天前
动态规划入门
算法·动态规划·代理模式
mjhcsp1 天前
P14987 全等(mjhcsp)
算法·题解·洛谷
(❁´◡`❁)Jimmy(❁´◡`❁)1 天前
Atcoder abc441A~F 题解
算法·深度优先·图论
少林码僧1 天前
2.30 传统行业预测神器:为什么GBDT系列算法在企业中最受欢迎
开发语言·人工智能·算法·机器学习·ai·数据分析