描述
有重复数字的全排列
样例
样例11
2
3
4
5
6
7输入: 1 1 2
输出:
[
[1,1,2],
[1,2,1],
[2,1,1]
]
思路
回溯,加个index,利用 set ,这样比较慢。
回溯的两种做法,一种是直接往 temp 数组里面放元素,一种是改变 nums 数组,得到全排列也可以通过交换两个数的位置得到,不是吗?
代码
1 | 92 ms |
更快一点的做法1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27class Solution {
public:
vector<vector<int>> permuteUnique(vector<int>& nums) {
vector<vector<int>> res;
if (nums.size() == 0) {
return res;
}
dfs(nums, res, 0);
return res;
}
void dfs(vector<int>& nums, vector<vector<int>>& res, int index) {
if (index == nums.size()) {
res.push_back(nums);
return;
}
unordered_set<int> uset;
for (int i = index; i < nums.size(); ++i) {
if (uset.find(nums[i]) == uset.end()) {
uset.insert(nums[i]);
swap(nums[i], nums[index]);
dfs(nums, res, index + 1);
swap(nums[i], nums[index]);
}
}
}
};