zoukankan      html  css  js  c++  java
  • [LeetCode] Permutations II

    Well, have you solved the nextPermutation problem? If so and you have handled the cases of duplicates at that problem, your code can be used in this problem. The idea is fairly simple:

    1. sort nums in ascending order, add it to res;
    2. generate the next permutation of nums using nextPermutation(), and add it to res;
    3. repeat 2 until the next permutation of nums returns to the sorted condition in 1.

    The code is as follows. For more about the idea of nextPermutation(), please visit this solution.

     1     bool nextPermutation(vector<int>& nums) {
     2         int k = -1;
     3         for (int i = nums.size() - 2; i >= 0; i--) {
     4             if (nums[i] < nums[i + 1]) {
     5                 k = i;
     6                 break;
     7             }
     8         }
     9         if (k == -1) {
    10             sort(nums.begin(), nums.end());
    11             return false;
    12         }
    13         int l = -1;
    14         for (int i = nums.size() - 1; i > k; i--) {
    15             if (nums[i] > nums[k]) {
    16                 l = i;
    17                 break;
    18             }
    19         }
    20         swap(nums[k], nums[l]);
    21         reverse(nums.begin() + k + 1, nums.end());
    22         return true;
    23     }
    24     vector<vector<int>> permuteUnique(vector<int>& nums) {
    25         vector<vector<int> > res;
    26         sort(nums.begin(), nums.end());
    27         res.push_back(nums);
    28         while (nextPermutation(nums))
    29             res.push_back(nums);
    30         return res;
    31     }

     Of coruse, this problem is designed for backtracking. You can modify the code in Permutations a little bit to solve this problem. In the following code, an unordered_set is used to prevent duplicates.

     1     void permutateUnique(vector<int>& nums, int start, vector<vector<int> >& res) {
     2         if (start == nums.size()) {
     3             res.push_back(nums);
     4             return;
     5         }
     6         unordered_set<int> st;
     7         for (int i = start; i < nums.size(); i++) {
     8             if (st.find(nums[i]) != st.end()) continue;
     9             st.insert(nums[i]);
    10             swap(nums[i], nums[start]);
    11             permutateUnique(nums, start + 1, res);
    12             swap(nums[i], nums[start]);
    13         }
    14     }
    15 
    16     vector<vector<int> > permuteUnique(vector<int>& nums) {
    17         vector<vector<int> > res;
    18         permutateUnique(nums, 0, res);
    19         return res;
    20     }

     You can also sort nums and then use position marks to prevent duplicates, like the following code.

     1     void permutateUnique(vector<int> nums, int start, vector<vector<int> >& res) {
     2         if (start == nums.size()) {
     3             res.push_back(nums);
     4             return;
     5         }
     6         for (int i = start; i < nums.size(); i++) {
     7             if (i != start && nums[i] == nums[start]) continue;
     8             swap(nums[i], nums[start]);
     9             permutateUnique(nums, start + 1, res);
    10         }
    11     }
    12 
    13     vector<vector<int> > permuteUnique(vector<int>& nums) {
    14         sort(nums.begin(), nums.end());
    15         vector<vector<int> > res;
    16         permutateUnique(nums, 0, res);
    17         return res;
    18     }
  • 相关阅读:
    【原创】绝对居中
    MSSQL数据库各角色权限
    如何升级至 XHTML?
    XHTML 语法
    5.4 删除一个元素节点或者文本节点
    Ajax实现无刷新的获取数据并绑定到GridView,以及无刷新更新数据[转]
    鼠标滑过时显示图片内容隐藏和鼠标滑过图片隐藏内容显示的两种小方法
    纯CSS3魔方的制作
    201920201学期 20192415 《网络空间安全专业导论》XOR加密
    201920201学期 20192415 《网络空间安全专业导论》第四周学习总结
  • 原文地址:https://www.cnblogs.com/jcliBlogger/p/4547994.html
Copyright © 2011-2022 走看看