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

文章目录

一. 力扣 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);
        }
    }
}
相关推荐
筱砚.17 分钟前
C++——lambda
开发语言·c++·算法
Eward-an31 分钟前
LeetCode 76. 最小覆盖子串(详细技术解析)
python·算法·leetcode·职场和发展
guygg8834 分钟前
基于ADMM的MRI-PET高质量图像重建算法MATLAB实现
开发语言·算法·matlab
moonlight030436 分钟前
类加载子系统
java·jvm·算法
baivfhpwxf202342 分钟前
ACS X轴回零程序 项目实战版
网络·数据库·算法
一叶落4381 小时前
LeetCode 219. 存在重复元素 II(C语言详解)
算法·哈希算法·散列表
像污秽一样1 小时前
算法设计与分析-习题2.4
数据结构·算法·排序算法
不想看见4041 小时前
Reverse Bits位运算基础问题--力扣101算法题解笔记
笔记·算法·leetcode
罗湖老棍子1 小时前
【例 2】数星星 Stars(信息学奥赛一本通- P1536)
数据结构·算法·树状数组·单点修改 区间查询
逆境不可逃1 小时前
LeetCode 热题 100 之 394. 字符串解码 739. 每日温度 84. 柱状图中的最大矩形
算法·leetcode·职场和发展