给定一个可蕴含反复数字的序列 nums,按任意程序 返回所有不反复的全排列。
/**
* @param {number[]} nums
* @return {number[][]}
*/
var permuteUnique = function(nums) {let res = []
function dfs(arr,rest){console.log(arr,rest)
if(arr.length === nums.length){res.push(arr)
return
}
for(let i=0;i<rest.length;i++){if(rest.indexOf(rest[i]) !== i){continue}else{arr.push(rest[i])
let newRest = [...rest]
newRest.splice(i,1)
dfs([...arr],newRest)
arr.pop()}
}
}
dfs([],nums)
return res
}
这道题还是思考了挺久的,看着一些解答办法的代码片段感觉不是那么很好了解。有的还要排序啊很麻烦觉着。
没想到早晨吃完饭回来居然了解了一些
回溯都晓得,重点是要去重
对于字符串的话去重简略一些
然而对于这道题,每一项外面也是一个字符串,还是剪枝比拟好。
既然剪枝的逻辑在于残余可选项中是否有反复项,那间接将有反复项的跳过不就行了?
举个简略实例
const nums = [1,1,2,2]
咱们执行上述代码,打印后果如下
[] [ 1, 1, 2, 2]
[1] [1, 2, 2]
[1, 1] [2, 2]
[1, 1, 2] [2]
[1, 1, 2, 2] []
[1, 2] [1, 2]
[1, 2, 1] [2]
[1, 2, 1, 2] []
[1, 2, 2] [1]
[1, 2, 2, 1] []
也就是说,rest 中如果有雷同的元素,我间接过滤掉,不必再塞进去了,感兴趣的能够打印一下比照成果。因为太长我就不展现了