专题三_穷举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);
    }
};
相关推荐
春花秋月夏海冬雪4 天前
代码随想录刷题Day49
回溯
KarrySmile5 天前
网格图--Day04--网格图DFS--2684. 矩阵中移动的最大次数,1254. 统计封闭岛屿的数目,130. 被围绕的区域
矩阵·深度优先·dfs·深度优先搜索·灵茶山艾府·网格图·网格图dfs
hansang_IR7 天前
【题解 | 两种做法】洛谷 P4208 [JSOI2008] 最小生成树计数 [矩阵树/枚举]
c++·算法·dfs·题解·枚举·最小生成树·矩阵树定理
让我们一起加油好吗15 天前
【基础算法】初识搜索:递归型枚举与回溯剪枝
c++·算法·剪枝·回溯·洛谷·搜索
CUC-MenG25 天前
2025牛客多校第九场 G.排列 A.AVL树 F.军训 个人题解
数学·dfs·dp·笛卡尔树·组合数·曼哈顿距离·树上dp
qiuyunoqy1 个月前
蓝桥杯算法之搜索章 - 3
c++·算法·蓝桥杯·深度优先·dfs·剪枝
CUC-MenG1 个月前
快速莫比乌斯变换(FMT)与莫比乌斯反演 例题:树上lcm
数学·dfs·fmt
CUC-MenG1 个月前
2025牛客多校第五场 K.完美旅程 J.最快覆盖问题 E.神秘异或操作 个人题解
数学·dfs·bfs·优先队列·二分·位运算·fmt·曼哈顿距离·fwt
yzzzzzzzzzzzzzzzzz1 个月前
leetcode热题——组合
算法·回溯·组合问题
屈臣1 个月前
AtCoder Beginner Contest 417 (A-E题解)
动态规划·dfs·二分