力扣78子集题解

java 复制代码
class Solution {
    List<Integer> t = new ArrayList<Integer>();
    List<List<Integer>> ans = new ArrayList<List<Integer>>();

    public List<List<Integer>> subsets(int[] nums) {
        dfs(0, nums);
        return ans;
    }

    public void dfs(int cur, int[] nums) {
        if (cur == nums.length) {
            ans.add(new ArrayList<Integer>(t));
            return;
        }
        t.add(nums[cur]);
        dfs(cur + 1, nums);
        t.remove(t.size() - 1);
        dfs(cur + 1, nums);
    }
}

使用回溯求解

cur代表的意思是处理nums[cur]这个数字

t.add和t.remove代表 当前的数字被选择和不被选择

以nums[] = {1,2,3}为例

求解过程就是

java 复制代码
选1选2选3
选1选2不选3
选1不选2选3
选1不选2不选3

不选1选2选3
不选1选2不选3
不选1不选2选3
不选1不选2不选3
相关推荐
样例过了就是过了1 小时前
LeetCode热题100 编辑距离
数据结构·c++·算法·leetcode·动态规划
wearegogog1232 小时前
MATLAB椭圆参数检测算法实现
数据库·算法·matlab
secondyoung2 小时前
Markdown数学公式语法速查手册
算法·编辑器·markdown·latex
君义_noip2 小时前
CSP-S 2025 提高级 第一轮(初赛) 阅读程序(1)
算法·深度优先·信息学奥赛·初赛
小O的算法实验室2 小时前
2026年IEEE TEVC,知识引导的竞争进化算法用于多解传感器-武器-目标分配问题,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
khalil10202 小时前
代码随想录算法训练营Day-46 动态规划13 | 647. 回文子串、516.最长回文子序列、动态规划总结
数据结构·c++·算法·leetcode·动态规划·回文子串·回文子序列
学习3人组2 小时前
柔性排产时序算法+中间过程+阶段目标 细化表格
算法·mes
he___H3 小时前
算法快与慢--哈希+双指针
算法·leetcode·哈希算法
呃呃本3 小时前
算法题(回溯)
算法
刀法如飞3 小时前
Rust数组去重的20种实现方式,AI时代用不同思路解决问题
人工智能·算法·ai编程