您的位置:首页 > 游戏 > 手游 > 找人做网站价格_销售平台公司_搜索引擎排名机制_必应搜索引擎网站

找人做网站价格_销售平台公司_搜索引擎排名机制_必应搜索引擎网站

2024/9/24 15:18:23 来源:https://blog.csdn.net/weixin_43724673/article/details/142392529  浏览:    关键词:找人做网站价格_销售平台公司_搜索引擎排名机制_必应搜索引擎网站
找人做网站价格_销售平台公司_搜索引擎排名机制_必应搜索引擎网站

理论基础

题目链接/文章讲解:代码随想录
视频讲解:带你学透回溯算法(理论篇)| 回溯法精讲!_哔哩哔哩_bilibili
回溯算法模板框架:

void backtracking(参数) {if (终止条件) {存放结果;return;}for (选择:本层集合中元素(树中节点孩子的数量就是集合的大小)) {处理节点;backtracking(路径,选择列表); // 递归回溯,撤销处理结果}
}

77. 组合

题目链接/文章讲解:代码随想录
视频讲解:带你学透回溯算法-组合问题(对应力扣题目:77.组合)| 回溯法精讲!_哔哩哔哩_bilibili
剪枝操作:带你学透回溯算法-组合问题的剪枝操作(对应力扣题目:77.组合)| 回溯法精讲!_哔哩哔哩_bilibili

class Solution {// 存储所有可能的组合结果List<List<Integer>> result = new ArrayList<>();// 用于记录当前递归路径上的值LinkedList<Integer> path = new LinkedList<>();// 主方法,接收两个参数:总的元素个数 n 和需要选取的元素个数 kpublic List<List<Integer>> combine(int n, int k) {// 调用回溯方法进行组合的生成backtracking(n, k, 1);// 返回所有可能的组合return result;}// 辅助的递归方法,用于生成所有可能的组合private void backtracking(int n, int k, int startIndex) {// 当路径中的元素数量达到 k 时,说明找到了一组有效的组合if (path.size() == k) {// 将当前路径作为一个完整的组合添加到结果列表中result.add(new ArrayList<>(path));// 结束本次递归return;}// 遍历剩余的元素for (int i = startIndex; i <= n; i++) {// 将当前元素添加到路径中path.add(i);// 继续递归,探索以当前元素开头的所有可能组合backtracking(n, k, i + 1);// 回溯:撤销上一步的选择,以便尝试其他可能性path.removeLast();}}
}

剪枝优化:

class Solution {// 存储所有可能的组合结果List<List<Integer>> result = new ArrayList<>();// 用于记录当前递归路径上的值LinkedList<Integer> path = new LinkedList<>();// 主方法,接收两个参数:总的元素个数 n 和需要选取的元素个数 kpublic List<List<Integer>> combine(int n, int k) {// 调用回溯方法进行组合的生成backtracking(n, k, 1);// 返回所有可能的组合return result;}// 辅助的递归方法,用于生成所有可能的组合private void backtracking(int n, int k, int startIndex) {// 当路径中的元素数量达到 k 时,说明找到了一组有效的组合if (path.size() == k) {// 将当前路径作为一个完整的组合添加到结果列表中result.add(new ArrayList<>(path));// 结束本次递归return;}// 遍历剩余的元素for (int i = startIndex; i <= (n - (k - path.size())) + 1; i++) {// 将当前元素添加到路径中path.add(i);// 继续递归,探索以当前元素开头的所有可能组合backtracking(n, k, i + 1);// 回溯:撤销上一步的选择,以便尝试其他可能性path.removeLast();}}
}

216.组合总和III

题目链接/文章讲解:代码随想录
视频讲解:和组合问题有啥区别?回溯算法如何剪枝?| LeetCode:216.组合总和III_哔哩哔哩_bilibili

class Solution {List<List<Integer>> result = new ArrayList<>();LinkedList<Integer> path = new LinkedList<>();int sum = 0; // 初始化 sumpublic List<List<Integer>> combinationSum3(int k, int n) {backtracing(k, n, 1);return result;}public void backtracing(int k, int n, int startIndex) {// 如果 path 的长度等于 k 且 sum 等于 n,则找到一个有效组合if (path.size() == k && sum == n) {result.add(new ArrayList<>(path));return;}// 如果 path 的长度已经等于 k 但 sum 不等于 n,则提前返回if (path.size() == k) {return;}// 从 startIndex 开始遍历到 9for (int i = startIndex; i <= 9 - (k - path.size()) + 1; i++) {path.add(i);sum += i;backtracing(k, n, i + 1); // 注意这里是 i + 1,而不是 startIndex + 1path.removeLast();sum -= i;}}
}

17.电话号码的字母组合

题目链接/文章讲解:代码随想录
视频讲解:还得用回溯算法!| LeetCode:17.电话号码的字母组合_哔哩哔哩_bilibili

class Solution {List<String> result = new ArrayList<>();LinkedList<String> path = new LinkedList<>();public List<String> letterCombinations(String digits) {if (digits == null || digits.length() == 0) {return result;}String[] numString = { "", "", "abc", "def", "ghi", "jkl", "mno", "pqrs", "tuv", "wxyz" };backtracing(digits, numString, 0);return result;}public void backtracing(String digits, String[] numString, int index) {if (index == digits.length()) {result.add(String.join("", path));return;}// 获取当前数字对应的字符串int digit = digits.charAt(index) - '0';String letters = numString[digit];// 遍历当前数字对应的字符串中的每个字符for (int i = 0; i < letters.length(); i++) {path.add(String.valueOf(letters.charAt(i)));backtracing(digits, numString, index + 1);path.removeLast(); // 回溯,移除最后一个字符}}
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com