算法奇妙屋(二十九)-递归、回溯与剪枝的综合问题 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);
        }
    }
}
相关推荐
小O的算法实验室5 分钟前
2026年IEEE TITS,面向按需外卖配送调度的特定问题知识与基于学习元启发式算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
加勒比海带667 分钟前
目标检测算法——农林行业数据集汇总附下载链接【Plant】
大数据·图像处理·人工智能·算法·目标检测
洛水水8 分钟前
【力扣100题】23. 螺旋矩阵
算法·leetcode·矩阵
影sir34 分钟前
不同测试数据下,该如何选择算法
算法·深度优先
潇湘散客1 小时前
CAX软件插件化设计实现牛刀小试
c++·算法·图形学·opengl
速易达网络1 小时前
2026,视觉算法正在经历一场静默革命
算法
WBluuue1 小时前
Codeforces 1094 Div1+2(ABCDE)
c++·算法
TENSORTEC腾视科技2 小时前
腾视科技大模型一体机解决方案:低成本私有化落地,重塑行业智能应用新格局
大数据·人工智能·科技·算法·ai·零售·大模型一体机
夏日听雨眠2 小时前
数据结构(循环队列)
数据结构·算法·链表
平行侠2 小时前
30MacLaren-Marsaglia算法故事文件
数据结构·算法