Permutations - LeetCode

Posted 真子集

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Permutations - LeetCode相关的知识,希望对你有一定的参考价值。

题目链接

Permutations - LeetCode

注意点

  • n个数字共有n!个全排列

解法

解法一:每一个排列用Next Permutation - LeetCode中的函数生成,一共有n!个。时间复杂度O(n)。

class Solution {
public:
    void nextPermutation(vector<int>& nums) {
        int n = nums.size(),i = n-2,j = n-1;
        while(i >= 0 && nums[i] >= nums[i+1]) i--;
        if(i >= 0)
        {
            while(nums[j] <= nums[i]) j--;
            swap(nums[i],nums[j]);
        }
        reverse(nums.begin()+i+1,nums.end());
    }
    vector<vector<int>> permute(vector<int>& nums) {
        vector<vector<int>> ret;
        int n = nums.size(),temp = 1,i;
        for(i = 1;i <= n;i++)
        {
            temp *= i;
        }
        while(temp >= 1)
        {
            ret.push_back(nums);
            nextPermutation(nums);
            temp--;
        }
        return ret;
    }
};

小结

  • 排列题,有许多变种

以上是关于Permutations - LeetCode的主要内容,如果未能解决你的问题,请参考以下文章

leetcode-Permutations II-47

[Leetcode 46]全排列 Permutations 递归

白菜刷LeetCode记-46. Permutations

LeetCode 46. 全排列(Permutations)

[Lintcode]15. Permutations/[Leetcode]46. Permutations

LeetCode46,47 Permutations, Permutations II