19.2.7 [LeetCode 47] Permutations II
Posted TobicYAL
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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 };
单纯只是把上一道改了一下
以上是关于19.2.7 [LeetCode 47] Permutations II的主要内容,如果未能解决你的问题,请参考以下文章
19.2.7 [LeetCode 45] Jump Game II
19.2.7 [LeetCode 48] Rotate Image
19.2.7 [LeetCode 49] Group Anagrams