全排列 II-47
给定一个可包含重复数字的序列,返回所有不重复的全排列。
示例:
输入: [1,1,2]
输出:
[
[1,1,2],
[1,2,1],
[2,1,1]
]
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/permutations-ii
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
思路
本题和全排列-46 的思路是一样的,只是在每次递归保存的时候,利用 Set 去重的特性,把每个值用字符串拼接的方式丢进 set 里去重,最后再处理成题目需要的格式即可。
let uniqSymbol = 'X' let permuteUnique = function (nums) { let n = nums.length if (n === 1) { return [nums] } let permuteSet = (nums) => { let n = nums.length if (n === 0) { return new Set() } if (n === 1) { return new Set(nums) } let res = new Set() for (let i = 0; i < n; i++) { let use = nums[i] if (use === undefined) { continue } let rest = nums.slice(0, i).concat(nums.slice(i + 1, n)) let restPermuteds = permuteSet(rest) restPermuteds.forEach((restPermuted) => { res.add(`${use}${uniqSymbol}${restPermuted}`) }) } return res } let permuted = permuteSet(nums) return Array.from(permuted).map((val) => val.split(uniqSymbol).map(Number)) }