19.2.7 [LeetCode 47] Permutations II

Given a collection of numbers that might contain duplicates, return all possible unique permutations.

Example:

Input: [1,1,2]
Output:
[
  [1,1,2],
  [1,2,1],
  [2,1,1]
]
 1 class Solution {
 2 public:
 3     vector<vector<int>> permuteUnique(vector<int>& nums) {
 4         set<vector<int>>ans;
 5         ans.insert(vector<int>(1, nums[0]));
 6         for (int i = 1; i < nums.size(); i++) {
 7             set<vector<int>>tmp = ans;
 8             ans.clear();
 9             for (auto j = tmp.begin(); j != tmp.end(); j++) {
10                 vector<int>now = *j;
11                 for (int k = 0; k <= now.size(); k++) {
12                     now.insert(now.begin() + k, nums[i]);
13                     ans.insert(now);
14                     now.erase(now.begin() + k);
15                 }
16             }
17         }
18         return vector<vector<int>>(ans.begin(),ans.end());
19     }
20 };
View Code

单纯只是把上一道改了一下

转载于:https://www.cnblogs.com/yalphait/p/10354993.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值