算法奇妙屋(二十九)-递归、回溯与剪枝的综合问题 2

文章目录

一. 力扣 77. 组合

1. 题目解析

组合是对顺序不敏感的, 即(1,2)和(2,1)相等

2. 算法原理

3. 代码

java 复制代码
class Solution {
    List<List<Integer>> ret;
    List<Integer> path;
    int n;
    int k;
    public List<List<Integer>> combine(int _n, int _k) {
        ret = new ArrayList<>();
        path = new ArrayList<>();
        n = _n;
        k = _k;
        dfs(1);
        return ret;
    }
    void dfs(int pos) {
        if (k == path.size()) {
            ret.add(new ArrayList(path));
            return;
        }
        for (int i = pos; i <= n; i++) {
            // 记录路径
            path.add(i);
            // 递归下一层
            dfs(i + 1);
            // 回溯
            path.remove(path.size() - 1);
        }
    }
}

二. 力扣 494. 目标和

1. 题目解析

这道题相信大家应该很眼熟, 在算法奇妙屋(二十二)-01背包问题(动态规划)这篇文章中讲过动态规划的解法

2. 解法一原理

3. 解法二原理

4. 算法一代码

java 复制代码
class Solution {
    int ret, cur;
    double a;
    public int findTargetSumWays(int[] nums, int target) {
        int sum = ret = cur = 0;
        for (int x : nums) {
            sum += x;
        }
        a = (sum + target) / 2.0;
        dfs(nums, 0);
        return ret;
    }
    void dfs(int[] nums, int pos) {
        if (cur == a) {
            ret++;
        }
        for (int i = pos; i < nums.length; i++) {
            cur += nums[i];
            dfs(nums, i + 1);
            cur -= nums[i];
        }
    }
}

5. 算法二代码

java 复制代码
class Solution {
    int ret;
    int path;
    int aim;

    public int findTargetSumWays(int[] nums, int target) {
        ret = path = 0;
        aim = target;
        dfs(nums, 0, 0);
        return ret;
    }

    void dfs(int[] nums, int pos, int path) {
        if (pos == nums.length) {
            if (path == aim) {
                ret++;
            }
            return;
        }
        dfs(nums, pos + 1, path + nums[pos]);
        dfs(nums, pos + 1, path - nums[pos]);
    }
}

三. 力扣 39. 组合总和

1. 题目解析

这道题让求的是组合+求和 = 目标值, 其中组合中元素可以重复

2. 算法原理

3. 代码

java 复制代码
class Solution {
    List<List<Integer>> ret;
    List<Integer> path;
    int t;
    public List<List<Integer>> combinationSum(int[] candidates, int target) {
        ret = new ArrayList<>();
        path = new ArrayList<>();
        t = target;
        dfs(candidates,0, 0);
        return ret;
    }

    void dfs(int[] nums, int sum, int pos) {
        if (sum >= t) {
            if (sum == t) {
                ret.add(new ArrayList(path));
            }
            return;
        }
        for (int i = pos; i < nums.length; i++) {
            if (sum + nums[i] <= t) {
                path.add(nums[i]);
                dfs(nums, sum + nums[i], i);
                path.remove(path.size() - 1);
            }
        }
    }
}

四. 力扣 784. 字母大小写全排列

1. 题目解析

按原来顺序, 英文字符变为大写和小写来进行全排列

2. 算法原理

3. 代码

java 复制代码
class Solution {
    StringBuilder path;
    List<String> ret;
    public List<String> letterCasePermutation(String s) {
        ret = new ArrayList<>();
        path = new StringBuilder();
        String ss = s.toLowerCase();
        dfs(ss, 0);
        return ret;
    }

    void dfs(String s, int pos) {
        if (pos == s.length()) {
            ret.add(path.toString());
            return;
        }
        char ch = s.charAt(pos);
        path.append(ch);
        dfs(s, pos + 1);
        path.deleteCharAt(path.length() - 1);
        if (ch < '0' || ch > '9') {
            path.append((char) (ch - 32));
            dfs(s, pos + 1);
            path.deleteCharAt(path.length() - 1);
        }
    }
}
相关推荐
kisshyshy13 小时前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
猿人谷20 小时前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络21 小时前
Stable Diffusion 视觉大模型微调技术深度调研
算法
复杂网络21 小时前
基于 Stable Diffusion 架构的视觉大模型代表性工作与原理深度解析
算法
MrZhao40021 小时前
Agent Loop 如何用 Hook 扩展:权限、日志与工具拦截
算法
MrZhao40021 小时前
Agent 为什么需要 Skills:别把所有知识都塞进 system prompt
算法
JieE2122 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2123 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack204 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树4 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色