算法奇妙屋(二十九)-递归、回溯与剪枝的综合问题 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);
        }
    }
}
相关推荐
Justice Young4 分钟前
算法分析与设计实验:贪心法求解0/1背包问题的局限性
算法
黎阳之光10 分钟前
无感定位·智管全域:黎阳之光人员无感定位管理系统,重新定义安全与效率
人工智能·物联网·算法·安全·数字孪生
小许同学记录成长24 分钟前
网格简化算法 — Edge Collapse(边塌缩)
qt·算法
凯瑟琳.奥古斯特27 分钟前
力扣1001网格照明解法
算法·leetcode·职场和发展
fengenrong29 分钟前
20260601
算法·深度优先·图论
晚笙coding32 分钟前
从“看起来像双指针”到真正的动态规划 —— 最长公共子序列
算法·动态规划
05候补工程师1 小时前
【考研高数核心突破】极限的本质、高频解题套路与海涅定理深度解析(附经典例题思维导图式拆解)
经验分享·笔记·考研·算法
智者知已应修善业1 小时前
【51单片机8个LED的花样12亮34熄56间隔78闪烁3秒3闪烁】2023-11-4
c++·经验分享·笔记·算法·51单片机
老鱼说AI1 小时前
统计学习方法第五章:从浅入深解析决策树
人工智能·深度学习·算法·决策树·机器学习·学习方法
KaMeidebaby1 小时前
卡梅德生物技术快报|蛋白修饰调控 NETosis 分子机制及实验研究进展
前端·数据库·人工智能·算法·百度