leetcode 46 全排列

简介: leetcode 46 全排列

全排列

b1036582ce6b4c408b0ce3edadab4371.png

每一个树枝都元素都只能出现一次

回溯法

class Solution {
public:
    vector<vector<int>> result;
    vector<int> path;
    void backtracking(vector<int> &nums)
    {
        if(path.size() == nums.size())
        {
            result.push_back(path);
            return;
        } 
        for(int i = 0 ; i<nums.size() ; i++)
        {
           auto it = find(path.begin(),path.end(),nums[i]);
           //如果这个元素在这个树枝之前用过,就跳出
           if(it == path.end()) 
           {
               path.push_back(nums[i]);
           }else
           {
               continue;
           }
            backtracking(nums);
            path.pop_back();
        }
        return;
    }
    vector<vector<int>> permute(vector<int>& nums) {
        backtracking(nums);
        return result;
    }
};

回溯标记法

f3aa8e3e984e4171838d6d9f09545125.png

class Solution {
public:
    vector<vector<int>> result;
    vector<int> path;
    void backtracking (vector<int>& nums, vector<bool>& used) {
        // 此时说明找到了一组
        if (path.size() == nums.size()) {
            result.push_back(path);
            return;
        }
        for (int i = 0; i < nums.size(); i++) {
            if (used[i] == true) continue; // path里已经收录的元素,直接跳过
            used[i] = true;
            path.push_back(nums[i]);
            backtracking(nums, used);
            path.pop_back();
            used[i] = false;
        }
    }
    vector<vector<int>> permute(vector<int>& nums) {
        result.clear();
        path.clear();
        vector<bool> used(nums.size(), false);
        backtracking(nums, used);
        return result;
    }
};

二刷

class Solution {
public:
    vector<vector<int>> result;
    vector<int> path;
    vector<bool> underNum;
    void track_back(vector<int>& nums )
    {
        if(path.size() >= nums.size())
        {
            result.push_back(path);
            return;
        }
        for(int i=0 ; i<nums.size();i++)
        {
            if(underNum[i] == true ) continue;
            underNum[i] = true;
            path.push_back(nums[i]);
            track_back(nums);
            path.pop_back();
            underNum[i] = false;
        }
        return;
    }
    vector<vector<int>> permute(vector<int>& nums) {
        if(nums.size() == 0 ) return result;
        underNum.assign(nums.size(),false);
        track_back(nums);
        return result;
    }
};
相关文章
|
1月前
|
Java
leetcode-46:全排列
leetcode-46:全排列
27 1
|
1月前
leetcode47全排列2刷题打卡
leetcode47全排列2刷题打卡
22 0
|
1月前
|
Java
46. 全排列 --力扣 --JAVA
给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。
28 0
|
8月前
|
测试技术
代码随想录Day24 LeetCode T491 递增子序列 LeetCode T46 全排列 LrrtCode T47 全排列II
代码随想录Day24 LeetCode T491 递增子序列 LeetCode T46 全排列 LrrtCode T47 全排列II
25 1
|
16天前
|
机器学习/深度学习 存储 算法
Python5种算法回溯+剪枝、字典序、递归交换、计数回溯、迭代法 实现全排列ll【力扣题47】
Python5种算法回溯+剪枝、字典序、递归交换、计数回溯、迭代法 实现全排列ll【力扣题47】
|
12天前
|
算法
【经典LeetCode算法题目专栏分类】【第11期】递归问题:字母大小写全排列、括号生成
【经典LeetCode算法题目专栏分类】【第11期】递归问题:字母大小写全排列、括号生成
|
16天前
|
存储 机器学习/深度学习 算法
python 3种算法 回溯法、字典序生成、递归交换 实现全排列【力扣46题】
python 3种算法 回溯法、字典序生成、递归交换 实现全排列【力扣46题】
|
1月前
|
算法
leetcode代码记录(全排列 II
leetcode代码记录(全排列 II
22 4
|
1月前
|
算法
leetcode代码记录(全排列
leetcode代码记录(全排列
19 1
|
1月前
|
Go
golang力扣leetcode 47.全排列II
golang力扣leetcode 47.全排列II
60 0