Leetcode 46. 全排列

2019-12-24  本文已影响0人  LonnieQ

题目

给定一个没有重复数字的序列,返回其所有可能的全排列。

示例:

输入: [1,2,3]
输出:
[
  [1,2,3],
  [1,3,2],
  [2,1,3],
  [2,3,1],
  [3,1,2],
  [3,2,1]
]

C++解法

class Solution {
    public:
    void backtrack(int n, vector<int> & nums, vector<vector<int>> & output, int first) {
        if (first == n) output.push_back(nums);
        for (int i = first; i < n; ++i) {
            swap(nums[first], nums[i]);
            backtrack(n, nums, output, first + 1);
            swap(nums[first], nums[i]);
        }
    }
    vector<vector<int>> permute(vector<int> nums) {
        vector<vector<int>> output;
        vector<int> nums_list;
        for (auto num: nums) nums_list.push_back(num);
        backtrack(nums.size(), nums_list, output, 0);
        return output;
    }
};

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/permutations
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

上一篇 下一篇

猜你喜欢

热点阅读