专题三_穷举vs暴搜vs深搜vs回溯vs剪枝_全排列

dfs解决 全排列&子集

1.全排列

link:46. 全排列 - 力扣(LeetCode)

全局变量+回溯

code

复制代码
class Solution {
public:
    vector<vector<int>> ans;
    vector<int> cur;
    vector<bool> used;
    vector<vector<int>> permute(vector<int>& nums) {
        // 暴力枚举
        used = vector<bool>(nums.size(), false);
        dfs(nums);
        return ans;
    }

    void dfs(vector<int>& nums)
    {   // 出口
        if(cur.size() == nums.size())
        {
            ans.push_back(cur);
            return;
        }
        // 主体
        for(int i = 0; i < nums.size(); i++)
        {
            if(used[i]) continue; // 剪枝
            cur.push_back(nums[i]);
            used[i] = true;
            dfs(nums);
            used[i] = false;
            cur.pop_back(); // 回溯
        }
    }
};

2.子集

link:78. 子集 - 力扣(LeetCode)

code

复制代码
class Solution {
public:
    vector<vector<int>> ans;
    vector<int> cur;
    vector<vector<int>> subsets(vector<int>& nums) {
        dfs(nums, 0);
        return ans;
    }

    void dfs(vector<int>& nums, int idx)// idx表示这次选择取舍的下标
    {
        // 出口
        if(idx >= nums.size())
        {
            ans.push_back(cur);
            return;
        }
        // 主体
        //      要了
        cur.push_back(nums[idx]);
        dfs(nums, idx + 1);
        cur.pop_back();// 回溯
        //      不要
        dfs(nums, idx + 1);
    }
};
相关推荐
咚咚轩3 天前
蓝桥杯178 全球变暖
dfs
阳洞洞4 天前
leetcode 93. Restore IP Addresses
leetcode·回溯
阳洞洞5 天前
leetcode 131. Palindrome Partitioning
leetcode·动态规划·回溯
闻缺陷则喜何志丹9 天前
【回溯 剪支 状态压缩】# P10419 [蓝桥杯 2023 国 A] 01 游戏|普及+
c++·算法·蓝桥杯·剪枝·回溯·洛谷·状态压缩
飞川撸码11 天前
【LeetCode 热题100】17:电话号码的字母组合(详细解析)(Go语言版)
算法·leetcode·golang·dfs
2301_8076114916 天前
310. 最小高度树
c++·算法·leetcode·深度优先·回溯
Flower#20 天前
D. Apple Tree Traversing 【Codeforces Round 1023 (Div. 2)】
c++·算法·图论·dfs
2301_8076114921 天前
47. 全排列 II
c++·算法·leetcode·回溯
Aric_Jones23 天前
FastDFS,分布式文件存储系统,介绍+配置+工具类
java·数据库·redis·分布式·idea·dfs
2301_807611491 个月前
126. 单词接龙 II
c++·算法·leetcode·深度优先·广度优先·回溯