【算法】递归+回溯+剪枝:78.子集

目录

1、题目链接

2、题目

3、解法(回溯+剪枝)

4、代码


1、题目链接

78.子集(LeetCode)

2、题目

3、解法(回溯+剪枝)

思路:

枚举子集(答案)的第一个数选谁,第二个数选谁,第三个数选谁,依此类推。

dfs 中的 i 表示现在要枚举选 nums[i] 到 nums[n−1] 中的一个数,添加到 path 末尾。

如果选 nums[j] 添加到 path 末尾,那么下一个要添加到 path 末尾的数,就要在 nums[j+1] 到 nums[n−1] 中枚举了。

注意:不需要在回溯中判断 i=n 的边界情况,因为此时不会进入循环,if i == n: return 这句话写不写都一样。

4、代码

cpp 复制代码
class Solution {
public:

    vector<int> path;       //存储当前路径
    vector<vector<int>> ans;//结果集

    void dfs( vector<int>& nums, int pos)//pos层数
    {
        ans.push_back(path);//增加结果集
          
        for(int i = pos; i < nums.size();i++ )
        {
            path.push_back(nums[i]);
            dfs(nums,i+1);//深搜
            path.pop_back();//回溯
        }
    }
    vector<vector<int>> subsets(vector<int>& nums) {
        dfs(nums,0);
        return ans;
    }
};
相关推荐
AI科技星7 小时前
质量定义方程常数k = 4π m_p的来源、推导与意义
服务器·数据结构·人工智能·科技·算法·机器学习·生活
摇摆的含羞草7 小时前
哈希(hash)算法使用特点及常见疑问解答
算法·哈希算法
smile_Iris7 小时前
Day 40 复习日
人工智能·深度学习·机器学习
仰泳的熊猫8 小时前
1077 Kuchiguse
数据结构·c++·算法·pat考试
火山kim8 小时前
经典论文研读报告:DAGGER (Dataset Aggregation)
人工智能·深度学习·机器学习
Coding茶水间8 小时前
基于深度学习的水果检测系统演示与介绍(YOLOv12/v11/v8/v5模型+Pyqt5界面+训练代码+数据集)
图像处理·人工智能·深度学习·yolo·目标检测·机器学习·计算机视觉
LYFlied8 小时前
【每日算法】LeetCode 19. 删除链表的倒数第 N 个结点
算法·leetcode·链表
踏浪无痕8 小时前
计算机算钱为什么会算错?怎么解决?
后端·算法·面试
夏乌_Wx8 小时前
练题100天——DAY28:找消失的数字+分发饼干
数据结构·算法
studytosky9 小时前
深度学习理论与实战:反向传播、参数初始化与优化算法全解析
人工智能·python·深度学习·算法·分类·matplotlib