Skip to content

Commit

Permalink
feat: 全排列 II
Browse files Browse the repository at this point in the history
  • Loading branch information
sl1673495 committed Jun 11, 2020
1 parent f08b136 commit e99d8bb
Showing 1 changed file with 39 additions and 0 deletions.
39 changes: 39 additions & 0 deletions 递归与回溯/全排列 II-47.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@

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))
}

console.log(permuteUnique([-1,2,-1,2,1,-1,2,1]))

0 comments on commit e99d8bb

Please sign in to comment.