46. 全排列

给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。

> 我的解法

class Solution {
private:
    void traversal(vector<int> &nums,vector<bool> &used,int startdex){
        if(startdex > nums.size()) return;
        if(path.size() == nums.size()){
            res.emplace_back(path);
        }
        for(int i = 0; i < nums.size(); i++){
            if(used[i] == false){
                path.emplace_back(nums[i]);
                used[i] = true;
                traversal(nums,used,i+1);
                used[i] = false;
                path.pop_back();
            }
        }
    }
public:
    vector<vector<int>> res;
    vector<int> path;
    vector<vector<int>> permute(vector<int>& nums){
        res.clear();
        path.clear();
        if(nums.size() == 1){
            res.emplace_back(nums);
            return res;
        } 
        vector<bool> used(nums.size(),false);
        traversal(nums,used,0);
        return res;
    }
};
posted @   xiazichengxi  阅读(16)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示
主题色彩