LeetCode:46. Permutations

在这里插入图片描述
解法一:回溯

class Solution {
public:
    vector<vector<int>> permute(vector<int>& nums) {
        vector<vector<int>> ret;
        vector<bool> used(nums.size(), false);
        vector<int> temp;
        helper(nums, ret, temp, used);
        return std::move(ret);
    }
private:
    void helper(vector<int>& nums, vector<vector<int>>& ret, vector<int>& temp, vector<bool>& used) {
        if (temp.size() == nums.size()) {
            ret.push_back(temp);
            return;
        }
        for (int i = 0; i < nums.size(); ++i) {
            if (used[i])
                continue;
            temp.push_back(nums[i]);
            used[i] = true;
            helper(nums, ret, temp, used);
            used[i] = false;
            temp.pop_back();
        }
    }
};

解法二:

class Solution {
public:
    vector<vector<int>> permute(vector<int>& nums) {
        vector<vector<int>> ret;
        helper(nums, ret, 0);
        return std::move(ret);
    }
private:
    void helper(vector<int>& nums, vector<vector<int>>& ret, int beg) {
        if (beg == nums.size()) {
            ret.push_back(nums);
            return;
        }
        for (int i = beg; i < nums.size(); ++i) {
            swap(nums[beg], nums[i]);
            helper(nums, ret, beg+1);
            swap(nums[beg], nums[i]);
        }
    }
};
//看第一个位置:所有的permutations,应该是所有数字都在第一个位置的时候加上其他数字的permutations。
//再细致一点说:第一个位置有了一个数,第二个位置需要把剩下的数字都有一遍,第三个位置也是把前两个剩下的数字都有一遍。。。

这个解法很有意思

posted @ 2019-08-23 21:00  于老师的父亲王老爷子  阅读(18)  评论(0编辑  收藏  举报