The Unique Permutations Algorithm with Duplicate Elements
- 时间:2020-09-17 14:26:24
- 分类:网络文摘
- 阅读:118 次
Given a collection of numbers that might contain duplicates, return all possible unique permutations.
Example:
Input: [1,1,2]
Output:
1 2 3 4 5 [ [1,1,2], [1,2,1], [2,1,1] ][ [1,1,2], [1,2,1], [2,1,1] ]
How to Get Unique Permuations in C++?
In fact, the C++ STL algorithm header provides the std::next_permutation() which deals with the duplicate elements in the candidate array. We just need to sort the array, then start permutating until the next_permutation() returns false.
1 2 3 4 5 6 7 8 9 10 11 12 | class Solution { public: vector<vector<int>> permuteUnique(vector<int>& nums) { vector<vector<int>> r; sort(begin(nums), end(nums)); r.push_back(nums); while (next_permutation(begin(nums), end(nums))) { r.push_back(nums); } return r; } }; |
class Solution {
public:
vector<vector<int>> permuteUnique(vector<int>& nums) {
vector<vector<int>> r;
sort(begin(nums), end(nums));
r.push_back(nums);
while (next_permutation(begin(nums), end(nums))) {
r.push_back(nums);
}
return r;
}
};Recursive Permutation Algorithm without Duplicate Result
Similar to The Permutation Algorithm for Arrays using Recursion, we can do this recursively by swapping two elements at each position. However, we need to keep tracking of the solution that has also been in the permutation result using a hash set.
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 | class Solution { public: vector<vector<int>> permuteUnique(vector<int>& nums) { vector<vector<int>> r; dfs(nums, 0, r, ""); return r; } private: unordered_set<string> used; void dfs(vector<int>& nums, int index, vector<vector<int>> &r, string key) { if (index == nums.size()) { if (!used.count(key)) { r.push_back(nums); used.insert(key); } } else { for (int i = index; i < nums.size(); ++ i) { swap(nums[i], nums[index]); dfs(nums, index + 1, r, key + std::to_string(nums[index])); swap(nums[i], nums[index]); } } } }; |
class Solution {
public:
vector<vector<int>> permuteUnique(vector<int>& nums) {
vector<vector<int>> r;
dfs(nums, 0, r, "");
return r;
}
private:
unordered_set<string> used;
void dfs(vector<int>& nums, int index, vector<vector<int>> &r, string key) {
if (index == nums.size()) {
if (!used.count(key)) {
r.push_back(nums);
used.insert(key);
}
} else {
for (int i = index; i < nums.size(); ++ i) {
swap(nums[i], nums[index]);
dfs(nums, index + 1, r, key + std::to_string(nums[index]));
swap(nums[i], nums[index]);
}
}
}
};In the worst cases, both implementations are O(N!) as N! is the total number of permutation results for N-size elements.
–EOF (The Ultimate Computing & Technology Blog) —
推荐阅读:我在落伍的那几年:一个个人站长的回忆录 给哪些网站暂时赚不到钱的站长鼓鼓劲 个人站长 建设网站贵在坚持 网站站长赚钱的6大好用的途径 整理6款站长赚钱方法 希望对你有所帮助 个人站长们常见的很多个网站盈利模式总结 春季饮食宜润肺,常吃炖梨既滋润又养人,口感甜香味道美 这道小学应用题比较难,解题关键是求相遇时间 豆腐搭配鸡蛋做出香酥可口的丸子,营养也很丰富 这道小学奥数题难倒多数学生,解题关键是比例
- 评论列表
-
- 添加评论