| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 【回溯】39. 组合总和 -> 正文阅读 |
|
[数据结构与算法]【回溯】39. 组合总和 |
题目:给定一个无重复元素的数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。 candidates 中的数字可以无限制重复被选取。 说明:
示例 1: 输入:candidates = [2,3,6,7], target = 7, 所求解集为: [ [7], [2,2,3] ] 示例 2: 输入:candidates = [2,3,5], target = 8, 所求解集为: [ [2,2,2,2], [2,3,3], [3,5] ] 题解:无限制重复被选取意味着取过的数可以再取,从上一层取任意数。 步骤:1.递归函数参数 这里依然是定义两个全局变量,存放结果集res和符合条件的结果path 参数:集合candidates 和目标值target。 本题还需要startIndex来控制for循环的起始位置,对于组合问题,什么时候需要startIndex呢? 如果是一个集合来求组合的话,就需要startIndex 如果是多个集合取组合,各个集合之间相互不影响,那么就不用startIndex 2.递归终止条件 从叶子节点可以清晰看到,终止只有两种情况,sum大于target和sum等于target。
3.单层搜索的逻辑 单层for循环依然是从startIndex开始,搜索candidates集合。 本题元素为可重复选取的,因此for循环中的递归不用i+1了,表示可以重复读取当前的数 剪枝:对总集合排序之后,如果下一层的sum(就是本层的 sum + candidates[i])已经大于target,就可以结束本轮for循环的遍历。
参考:代码随想录 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/8 5:04:57- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |