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

文章目录

一. 力扣 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);
        }
    }
}
相关推荐
BirdenT2 小时前
20260519紫题训练
c++·算法
csdn_aspnet8 小时前
C语言 Lomuto分区算法(Lomuto Partition Algorithm)
c语言·开发语言·算法
谙弆悕博士8 小时前
【附C源码】从零实现C语言堆数据结构:原理、实现与应用
c语言·数据结构·算法··数据结构与算法
gaosushexiangji11 小时前
DIC系统推荐:基于千眼狼三维数字图像相关的无人机旋翼疲劳试验全场应变与位移测量
人工智能·算法
小王C语言13 小时前
【线程概念与控制】:线程封装
jvm·c++·算法
kyle~13 小时前
工程数学---点云配准卡布施(Kabsch)算法(求解最优旋转矩阵)
线性代数·算法·矩阵
张二娃同学13 小时前
03_变量常量与输入输出_printf与scanf详解
算法
江南十四行14 小时前
并发编程(一)
java·jvm·算法
z2005093014 小时前
今日算法(依旧二叉树)
算法·leetcode·职场和发展
Zxc_14 小时前
《遗传算法:从自然选择到Rastrigin函数优化,手写一个完整的进化求解器》
算法