力扣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
相关推荐
独断万古他化2 小时前
【算法通关】二叉树中的深搜:DFS 递归解题套路
算法·二叉树·深度优先·dfs·递归
㓗冽2 小时前
2026.03.27(第三天)
数据结构·c++·算法
sali-tec2 小时前
C# 基于OpenCv的视觉工作流-章44-直线卡尺
图像处理·人工智能·opencv·算法·计算机视觉
Magic--2 小时前
经典概率题:飞机座位分配问题(LeetCode 1227)超详细解析
算法·leetcode·职场和发展
urkay-2 小时前
Android 图片轮廓提取与重叠轮廓合并处理
android·算法·iphone
七七肆十九2 小时前
PTA 7-38 数列求和-加强版
数据结构·算法
SWAGGY..2 小时前
【C++初阶】:(5)内存管理
java·c++·算法
Zarek枫煜3 小时前
zig与C3的算法 -- 桶排序
c语言·嵌入式硬件·算法
Rooting++3 小时前
C语言中的共用体应用场景
算法