代码随想录第25天|216.组合总和III 17.电话号码的字母组合

216.组合总和III 

216. 组合总和 III - 力扣(LeetCode)

代码随想录 (programmercarl.com)

和组合问题有啥区别?回溯算法如何剪枝?| LeetCode:216.组合总和III_哔哩哔哩_bilibili

找出所有相加之和为 n 的 k 个数的组合,且满足下列条件:

  • 只使用数字1到9
  • 每个数字 最多使用一次 

返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次,组合可以以任何顺序返回。

示例 1:

输入: k = 3, n = 7
输出: [[1,2,4]]
解释:
1 + 2 + 4 = 7
没有其他符合的组合了。

示例 2:

输入: k = 3, n = 9
输出: [[1,2,6], [1,3,5], [2,3,4]]
解释:
1 + 2 + 6 = 9
1 + 3 + 5 = 9
2 + 3 + 4 = 9
没有其他符合的组合了。

示例 3:

输入: k = 4, n = 1
输出: []
解释: 不存在有效的组合。
在[1,9]范围内使用4个不同的数字,我们可以得到的最小和是1+2+3+4 = 10,因为10 > 1,没有有效的组合。

第一反应和昨天的77.组合的解法相同,不过对于剪枝部分以及n和k怎么应用我还是有点不懂。

看了卡哥的题解,发现自己对于题目的理解还是有些偏差。首先,该题题意可以理解为:在[1,2,3,4,5,6,7,8,9]这个集合中找到和为n的k个数的组合。K相当于树的深度。

回溯三部曲

1、确定参数和返回值:一个一维数组path来存放符合条件的结果,一个二位数组result来存放结果集:

List<List<Integer>> result = new ArrayList<>(); // 用于存储最终结果的列表
LinkedList<Integer> path = new LinkedList<>(); // 用于存储当前组合的列表

还需要的参数有:n,k,path路径中元素的综合sum,下一层for循环搜索的起始位置startIndex:
 

private void backTracking(int targetSum, int k, int startIndex, int sum) {}

2、确定终止条件:path.size和k相等的时候终止,sum和targetSum相等的时候用result收集当前结果:

if (path.size() == k) {if (sum == targetSum) result.add(new ArrayList<>(path));return;
}

3、单层搜索的过程:

for (int i = startIndex; i <= 9 ; i++) {path.add(i); // 将当前数字加入组合列表sum += i; // 更新累加和backTracking(targetSum, k, i + 1, sum); // 递归搜索下一个数字path.removeLast(); // 回溯:移除最后加入的数字,以便尝试其他可能的数字sum -= i; // 回溯:减去移除的数字,恢复累加和
}

 剪枝:

1、已选元素的值已经大于总和,就没有必要再往后遍历了

2、for循环的位置可以剪枝:i <= 9 - (k - path.size()) + 1就可以了。

综合代码

class Solution {List<List<Integer>> result = new ArrayList<>(); // 用于存储最终结果的列表LinkedList<Integer> path = new LinkedList<>(); // 用于存储当前组合的列表public List<List<Integer>> combinationSum3(int k, int n) {backTracking(n, k, 1, 0); // 调用回溯算法寻找符合条件的组合return result; // 返回最终结果}private void backTracking(int targetSum, int k, int startIndex, int sum) {// 减枝:如果当前累加的和已经大于目标值,则停止当前路径的搜索if (sum > targetSum) {return;}// 如果当前组合的元素数量已经达到要求,且当前累加和等于目标值,将当前组合加入结果列表if (path.size() == k) {if (sum == targetSum) result.add(new ArrayList<>(path));return;}// 减枝:根据剩余可用数字的数量和目标组合元素数量,确定可用的起始数字范围for (int i = startIndex; i <= 9 - (k - path.size()) + 1; i++) {path.add(i); // 将当前数字加入组合列表sum += i; // 更新累加和backTracking(targetSum, k, i + 1, sum); // 递归搜索下一个数字path.removeLast(); // 回溯:移除最后加入的数字,以便尝试其他可能的数字sum -= i; // 回溯:减去移除的数字,恢复累加和}}
}

 17.电话号码的字母组合 

17. 电话号码的字母组合 - 力扣(LeetCode)

代码随想录 (programmercarl.com)

还得用回溯算法!| LeetCode:17.电话号码的字母组合_哔哩哔哩_bilibili

有了上一题的基础和思路之后,明白这一题要用回溯,也知道树怎么画,但是对于代码怎么实现还是有些不太明白。

看了卡哥视频题解:

从图中可以看出,遍历的深度就是【2、3】数组的长度,叶子节点就是我们要收集的结果。

回溯三部曲

1、确定参数:全局变量:一个字符串S手机叶子节点的结果,然后用一个字符串数组result把结果收集起来;局部变量:string digits和index,index用来遍历digits的同时记录遍历到digits的第几个数字;

2、确定终止条件:index=digits.size

3、确定单层遍历的逻辑:取index指向的数字,取该数字对应的字母:提前把index中的数字和其对应的字母集用map存储起来

综合代码

class Solution {// 设置全局列表存储最后的结果List<String> list = new ArrayList<>();// 主函数,传入数字字符串,返回所有可能的字母组合public List<String> letterCombinations(String digits) {if (digits == null || digits.length() == 0) {return list; // 如果输入为空,则直接返回结果列表}// 初始对应所有的数字,为了直接对应2-9,新增了两个无效的字符串""String[] numString = {"", "", "abc", "def", "ghi", "jkl", "mno", "pqrs", "tuv", "wxyz"};// 迭代处理backTracking(digits, numString, 0);return list;}// 每次迭代获取一个字符串,所以会设计大量的字符串拼接,所以这里选择更为高效的 StringBuilderStringBuilder temp = new StringBuilder();// 比如 digits 如果为 "23",num 为 0,则 str 表示 2 对应的 "abc"public void backTracking(String digits, String[] numString, int num) {// 遍历全部一次记录一次得到的字符串if (num == digits.length()) {list.add(temp.toString()); // 当数字索引已经达到 digits 字符串的长度时,将当前拼接好的字符串加入结果列表return;}// str 表示当前 num 对应的字符串String str = numString[digits.charAt(num) - '0'];for (int i = 0; i < str.length(); i++) {temp.append(str.charAt(i)); // 将当前字符追加到临时 StringBuilder 中backTracking(digits, numString, num + 1); // 递归调用,处理下一个数字temp.deleteCharAt(temp.length() - 1); // 剔除末尾的字符,为下一个迭代做准备}}
}


 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/783765.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【KingSCADA】播放语音

1.函数介绍 PlaySound(string strWaveFileName, int nMode);下面是官方帮助文档中的解释&#xff1a; 2.生成语音文件 3.使用脚本播放音频文件 将音频文件存放在工程目录下面&#xff0c;我存放在了…\Resources\文件夹下&#xff1a; 我简单的写了一个定时1分钟播放一次语…

Fluent循环流动案例(模拟循环泵,含换热、散热、VOF、UDF)

在此特意记录下循环通道的fluent思路和参数设置 该案例中&#xff0c;主要关注的是催化剂域的温度变化情况&#xff0c;因此需要监控的是温度的变化曲线&#xff0c;关于泵如何进行模拟&#xff0c;这里有两种思路&#xff0c;一种是用风扇代替泵&#xff0c;优点是整个流体域基…

HarmonyOS ArkTS 骨架屏加载显示(二十五)

目录 前言1、骨架屏代码显示2、代码中引用3、效果图展示 前言 所谓骨架屏&#xff0c;就是在页面进行耗时加载时&#xff0c;先展示的等待 UI, 以告知用户程序目前正在运行&#xff0c;稍等即可。 等待的UI大部分是 loading 转圈的弹窗&#xff0c;有的是自己风格的小动画。其实…

武汉大学开设 “雷军班”:计算机专业、今年招收 15 名本科生。武汉大学已经联合小米成立了机器系

更多精彩内容在公众号。 3月25日&#xff0c;武汉大学官方网站发布了一则新闻&#xff0c;报道了校长张平文对计算机学院的调研活动。在报道中&#xff0c;张平文校长特别强调了关于“雷军班”及机器人系的发展规划。他表示&#xff0c;希望计算机学院能够立足于更高层次&#…

【python从入门到精通】-- 第三战:输入输出 运算符

&#x1f308; 个人主页&#xff1a;白子寰 &#x1f525; 分类专栏&#xff1a;python从入门到精通&#xff0c;魔法指针&#xff0c;进阶C&#xff0c;C语言&#xff0c;C语言题集&#xff0c;C语言实现游戏&#x1f448; 希望得到您的订阅和支持~ &#x1f4a1; 坚持创作博文…

前端虚拟滚动列表 vue虚拟列表

前端虚拟滚动列表 在大型的企业级项目中经常要渲染大量的数据&#xff0c;这种长列表是一个很普遍的场景&#xff0c;当列表内容越来越多就会导致页面滑动卡顿、白屏、数据渲染较慢的问题&#xff1b;大数据量列表性能优化&#xff0c;减少真实dom的渲染 看图&#xff1a;绿色…

Prometheus +Grafana +node_exporter可视化监控Linux + windows虚机

1、介绍 背景&#xff1a;需要对多台虚机进行负载可视乎监控&#xff0c;并进行及时的报警 2、架构图 node_exporter &#xff1a;主要是负责采集服务器的信息。 Prometheus &#xff1a;主要是负责存储、抓取、聚合、查询方面。 Grafana &#xff1a; 主要是…

Pandas | value_counts() 的详细用法

value_counts() 函数得作用 用来统计数据表中&#xff0c;指定列里有多少个不同的数据值&#xff0c;并计算每个不同值有在该列中的个数&#xff0c;同时还能根据指定得参数返回排序后结果。 返回得是Series对象 value_counts(values,sortTrue, ascendingFalse, normalizeFal…

SSTI 服务器端模板注入(Server-Side Template Injection)

1.Web_python_template_injection {{}}是变量包裹标识符&#xff0c;里面存放的是一个变量&#xff0c;当你输入 http://61.147.171.105:55121/{{8*8}} 执行成功&#xff0c;说明存在模版注入。接下来&#xff0c;开始想办法编代码拿到服务器的控制台权限 。 首先&#xff0c…

unity 打包安卓错误汇集

Failed to find target with hash string "android-34’ in: D:Pr 他说找不到sdk34level的我用as打开后卸载又重装&#xff0c;最后解决了 我放到Plugins/Android/下面的Java代码没有被编译 这个不知道为什么。我故意把代码写的有问题&#xff0c;会报错那种&#xff…

Java中常见的锁策略

目录 乐观锁 vs 悲观锁 悲观锁: 乐观锁&#xff1a; 重量级锁 vs 轻量级锁 ⾃旋锁&#xff08;Spin Lock&#xff09; 公平锁 vs 非公平锁 可重⼊锁 vs 不可重入锁 读写锁 乐观锁 vs 悲观锁 悲观锁: 总是假设最坏的情况&#xff0c;每次去拿数据的时候都认为别…

AES加密解密算法

一&#xff0c;AES算法概述 AES属于分组加密&#xff0c;算法明文长度固定为128位&#xff08;单位是比特bit&#xff0c;1bit就是1位&#xff0c;128位等于16字节&#xff09; 而密钥长度可以是128、192、256位 当密钥为128位时&#xff0c;需要循环10轮完成加密&#xff0…

【Threejs基础教程-光影篇】5.2 Threejs 阴影系统

5.2 Threejs阴影系统 学习ThreeJS的捷径在用光影系统之前threejs是实时光影web端目前没有优质的实时光影实时光影会大幅增加渲染压力没有独显的电脑不建议添加实时光影 阴影配置什么样的灯光可以产生阴影什么样的物体可以产生阴影和接受阴影注意开启阴影渲染灵活运用阴影 平行光…

判断一个数据能否同时被3和5整除

一、运行结果&#xff1b; 二、源代码&#xff1b; # define _CRT_SECURE_NO_WARNINGS # include <stdio.h>int main() {//初始化变量值&#xff1b;int a 0;//提示用户printf("请输入一个整数\n");//获取用户输入数据&#xff1b;scanf("%d", &am…

Spring Boot项目启动过程中为什么日志打印没有显示完整包名呢?

一、前言 不知道大家注意过没有&#xff0c;在Spring Boot项目启动过程中日志打印并没有显示完整的报名&#xff0c;而是显示一些o.a.c&#xff0c;o.s.web形式的包名&#xff0c;如下图&#xff1a; 这是为什么呢&#xff1f; 二、原理 首先&#xff0c;我们先看一下Spring…

WordPress AutomaticPlugin SSRF漏洞复现(CVE-2024-27954)

0x01 产品简介 WordPress是一款免费开源的内容管理系统(CMS),最初是一个博客平台,但后来发展成为一个功能强大的网站建设工具,适用于各种类型的网站,包括个人博客、企业网站、电子商务网站等,并逐步演化成一款内容管理系统软件。 0x02 漏洞概述 WordPress AutomaticPlu…

01-XML-04XML处理

XML处理 DOM DOM解析要求解析器将整个XML文件全部加载到内存中&#xff0c;生成一个Document对象。 优点&#xff1a;元素和元素之间保留结构&#xff0c;关系&#xff0c;可以针对元素进行增删改查操作。 缺点&#xff1a;如果XML文件过大&#xff0c;可能会导致内存溢出。SA…

【QT入门】 QListWidget各种常见用法详解之列表模式

往期回顾 【QT入门】 Qt代码创建布局之setLayout使用-CSDN博客 【QT入门】 Qt代码创建布局之多重布局变换与布局删除技巧-CSDN博客 【QT入门】 QTabWidget各种常见用法详解-CSDN博客 【QT入门】 QListWidget各种常见用法详解之列表模式 QListWidget有列表和图标两种显示模式&a…

springboot论坛管理系统

论坛管理系统 摘要&#xff1a; 在社会快速发展的影响下&#xff0c;论坛管理系统继续发展&#xff0c;使论坛管理系统的管理和运营比过去十年更加信息化。依照这一现实为基础&#xff0c;设计一个快捷而又方便的网上论坛管理系统是一项十分重要并且有价值的事情。对于传统的论…

一篇讲明白 Hadoop 生态的三大部件

文章目录 每日一句正能量前言01 HDFS02 Yarn03 Hive04 HBase05 Spark及Spark Streaming关于作者推荐理由后记赠书活动 每日一句正能量 黎明时怀着飞扬的心醒来&#xff0c;致谢爱的又一天&#xff0c;正午时沉醉于爱的狂喜中休憩&#xff0c;黄昏时带着感恩归家&#xff0c;然后…