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

文章目录

一. 力扣 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);
        }
    }
}
相关推荐
sali-tec2 小时前
C# 基于OpenCv的视觉工作流-章20-仿射变换
图像处理·人工智能·opencv·算法·计算机视觉
u0109272712 小时前
实时数据流处理
开发语言·c++·算法
独自破碎E3 小时前
【滑动窗口+计数】LCR015找到字符串中所有字母异位词
数据结构·算法
Trouvaille ~3 小时前
【Linux】线程同步与互斥(一):线程互斥原理与mutex详解
linux·运维·服务器·c++·算法·线程·互斥锁
2501_940315263 小时前
leetcode统计一致字符串的数目(哈希表)
算法·哈希算法·散列表
清铎3 小时前
项目_Agent实战
开发语言·人工智能·深度学习·算法·机器学习
J_liaty3 小时前
SpringBoot 自定义注解实现接口加解密:一套完整的多算法方案
java·spring boot·算法
m0_748708053 小时前
C++代码移植性设计
开发语言·c++·算法
Σίσυφος19003 小时前
特征值分解eig
人工智能·算法