算法奇妙屋(二十七)-全排列与子集问题

文章目录

一. 力扣 46. 全排列

1. 题目解析

题目为高中学习过的全排列, 注意这里每个数字都是不重复的

2. 算法原理

3. 代码

java 复制代码
class Solution {
    boolean[] check;
    List<List<Integer>> ret;
    List<Integer> path;
    int n;

    public List<List<Integer>> permute(int[] nums) {
        n = nums.length;
        check = new boolean[n];
        ret = new ArrayList<>();
        path = new ArrayList<>();
        dfs(nums);
        return ret;
    }

    void dfs(int[] nums) {
        if (path.size() == n) {
            ret.add(new ArrayList(path));
            return;
        }
        for (int i = 0; i < n; i++) {
            if (!check[i]) {
                path.add(nums[i]);
                check[i] = true;
                dfs(nums);
                // 递归完成, 说明已经到达最后一个数,开始回溯
                path.remove(path.size() - 1);
                check[i] = false;
            }
        }
    }
}

二. 力扣 78. 子集

1. 题目解析

子集本身就是一个集合, 空集是所有集合的子集, 这里所有元素是无序的

2. 算法原理

(1) 解法一

(2) 解法二

3. 代码

(1) 解法一代码

java 复制代码
class Solution {
    List<List<Integer>> ret;
    List<Integer> path;

    public List<List<Integer>> subsets(int[] nums) {
        ret = new ArrayList<>();
        path = new ArrayList<>();
        dfs(nums, 0);
        return ret;
    }

    void dfs(int[] nums, int i) {
        if (i == nums.length) {
            ret.add(new ArrayList(path));
            return;
        }
        // 不选择
        dfs(nums, i + 1);
        // 选择
        path.add(nums[i]);
        dfs(nums, i + 1);
        path.remove(path.size() - 1);
    }
}

(2) 解法二代码

java 复制代码
class Solution {
    List<List<Integer>> ret;
    List<Integer> path;

    public List<List<Integer>> subsets(int[] nums) {
        ret = new ArrayList<>();
        path = new ArrayList<>();
        dfs(nums, 0);
        return ret;
    }

    void dfs(int[] nums, int pos) {
        ret.add(new ArrayList(path));
        for (int i = pos; i < nums.length; i++) {
            path.add(nums[i]);
            dfs(nums, i + 1);
            path.remove(path.size() - 1);
        }
    }
}
相关推荐
持续学习的程序员+113 小时前
强化学习Q-chunking算法
算法
Polaris北13 小时前
第二十七天打卡
开发语言·c++·算法
风吹乱了我的头发~13 小时前
Day30:2026年2月20日打卡
算法
blackicexs14 小时前
第五周第五天
算法
不吃橘子的橘猫14 小时前
《集成电路设计》复习资料2(设计基础与方法)
学习·算法·fpga开发·集成电路·仿真·半导体
halen33314 小时前
How Masters Tool Fixed My Digital Disaster
算法·均值算法·推荐算法
重生之后端学习15 小时前
78. 子集
java·数据结构·算法·职场和发展·深度优先
摸鱼仙人~15 小时前
0-1背包与完全背包:遍历顺序背后的秘密
人工智能·算法
juleskk15 小时前
2.15 复试训练
开发语言·c++·算法
那起舞的日子15 小时前
斐波那契数列
java·算法