LeetCode刷题day25||216.组合总和III17.电话号码的字母组合--回溯

news/2024/4/26 22:00:03/文章来源:https://blog.csdn.net/wangjianhs/article/details/127621540

文章目录

  • 216.组合总和III
    • 题目描述
    • 思路分析
    • 代码
  • 17.电话号码的字母组合
    • 题目描述
    • 思路分析
    • 代码

216.组合总和III

题目描述

在这里插入图片描述
题目链接

思路分析

相对于77. 组合 (opens new window),无非就是多了一个限制,本题是要找到和为n的k个数的组合,而整个集合已经是固定的了[1,…,9]。
在这里插入图片描述
图中,可以看出,只有最后取到集合(1,3)和为4 符合条件。

代码

class Solution {
private:vector<vector<int>> result;vector<int> path;void backtracking(int targetSum, int k, int sum, int startIndex) {if (path.size() == k) {if (sum == targetSum) {result.push_back(path);}return;}for (int i = startIndex; i <= 9; i++) {sum += i;path.push_back(i);backtracking(targetSum, k, sum, i + 1);sum -= i;path.pop_back();}}
public:vector<vector<int>> combinationSum3(int k, int n) {result.clear();path.clear();backtracking(n, k, 0, 1);return result;}
};

剪枝

class Solution {
private:vector<vector<int>> result;vector<int> path;void backtracking(int targetSum, int k, int sum, int startIndex) {if (sum > targetSum) return;if (path.size() == k) {if (sum == targetSum) {result.push_back(path);}return;}for (int i = startIndex; i <= 9 - (k - path.size()) + 1; i++) {sum += i;path.push_back(i);backtracking(targetSum, k, sum, i + 1);sum -= i;path.pop_back();}}
public:vector<vector<int>> combinationSum3(int k, int n) {result.clear();path.clear();backtracking(n, k, 0, 1);return result;}
};

17.电话号码的字母组合

题目描述

在这里插入图片描述
题目链接

思路分析

问题

  • 数字和字母如何映射
  • 两个字母就两个for循环,三个字符我就三个for循环,以此类推
  • 输入1 * #按键等等异常情况
    可以使用map或者定义一个二维数组,例如:string letterMap[10],来做映射
const string letterMap[10] = {"", // 0"", // 1"abc", // 2"def", // 3"ghi", // 4"jkl", // 5"mno", // 6"pqrs", // 7"tuv", // 8"wxyz", // 9
};

例如:输入:“23”,抽象为树形结构,如图所示:
在这里插入图片描述
图中可以看出遍历的深度,就是输入"23"的长度,而叶子节点就是我们要收集的结果,输出[“ad”, “ae”, “af”, “bd”, “be”, “bf”, “cd”, “ce”, “cf”]。

代码

class Solution {
private:const string letterMap[10] = {"","","abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"};
public:vector<string> result;string s;void backtracking(const string& digits, int index) {if (index == digits.size()) {result.push_back(s);return;}int digit = digits[index] - '0';string letters = letterMap[digit];for (int i = 0; i < letters.size(); i++) {s.push_back(letters[i]);backtracking(digits, index + 1);s.pop_back();}}vector<string> letterCombinations(string digits) {s.clear();result.clear();if (digits.size() == 0) return result;backtracking(digits, 0);;return result;}
};

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

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

相关文章

基于全志T133-s3(Tina Linux)移植7寸RGB显示屏驱动

基于全志T133-s3&#xff08;Tina Linux&#xff09;移植7寸RGB显示屏驱动1.硬件电路2.LCD实物图3.LCD 的驱动4.uboot配置4.1.配置文件4.2.uboot设备树5.kernel配置5.1.内核配置5.2.设备树配置6.测试屏幕7.LVGL实测1.硬件电路 2.LCD实物图 3.LCD 的驱动 Tina Linux 提供了一套…

查题公众号搭建

查题公众号搭建 本平台优点&#xff1a; 多题库查题、独立后台、响应速度快、全网平台可查、功能最全&#xff01; 1.想要给自己的公众号获得查题接口&#xff0c;只需要两步&#xff01; 2.题库&#xff1a; 查题校园题库&#xff1a;查题校园题库后台&#xff08;点击跳转…

TI Application Notes_Programming Chirp Parameters in TI Radar Devices

Application Notes_Programming Chirp Parameters in TI Radar Devices 1 介绍 system requirement and chirp configuration:系统要求决定了波形或者chirp如何配置。甲方首先提出要求,然后乙方根据要求进行chirp设计。chirp参数的不同会影响系统的参数,如Rmax,Vmax,Rre…

107.(前端)分类管理增加值实现——使用elementui中的动态编辑标签发送请求

1.概述 本节要实现的功能就是&#xff0c;当我们点击动态编辑标签时&#xff0c;丢失焦点或者回车时&#xff0c;发送请求。 2.流程 handleInputConfirm()中&#xff0c;验证form输入框中是否存在值&#xff0c;若存在添加数据到val&#xff0c;若不存在&#xff0c;就制空va…

RHCE(逻辑卷LVM,NFS服务)

LVM逻辑卷管理&#xff0c; 是将一个或多个硬盘的分区在逻辑上集合&#xff0c;相当于一个大硬盘来使用&#xff0c;当硬盘的空间不够用的时候&#xff0c;可以继续将其它的硬盘的分区加入其中&#xff0c;这样可以实现磁盘空间的动态管理&#xff0c;相对于普通的磁盘分区有很…

《循序渐进学docker》书摘

循序渐进学docker笔记摘要 docker工作流程docker版本控制 和增量更新docker制作和下发镜像流程图windows安装 :docker官网下载docker ToolDbxdocker搭建个人博客wordpressdocker搭建本地gitlab服务docker基本概念:镜像 容器 仓库docker指令和基本用法docker工作流程

MySQL调优之关联查询优化

我们准备如下两个表&#xff0c;并插入数据。 #分类 CREATE TABLE IF NOT EXISTS type ( id INT(10) UNSIGNED NOT NULL AUTO_INCREMENT, card INT(10) UNSIGNED NOT NULL, PRIMARY KEY (id) ); #图书 CREATE TABLE IF NOT EXISTS book ( bookid INT(10) UNSIGNED NOT NULL AU…

天翼物联亮相2022中国信息通信业发展高层论坛

近日&#xff0c;由中国通信企业协会主办的2022中国信息通信业发展高层论坛成功召开&#xff0c;天翼物联受邀出席论坛并分享了中国电信5G赋能未来的创新实践&#xff0c;共话“万物智联”发展未来。 本次论坛以“数智赋能 共创未来”为主题。在论坛专题报告环节&#xff0c;天…

同元软控新一代复杂装备虚拟试验解决方案与实践

在各类复杂装备工程研制中&#xff0c;试验的重要性是毋庸置疑的。试验作为整个研制流程中必不可少的环节&#xff0c;往往是物料、时间、经济等成本消耗最大的阶段。以航空发动机为例&#xff0c;据统计&#xff0c;现代航空发动机整体研制成本中&#xff0c;试验及试验所需的…

《2022中国企业数字化办公创新与实践产业研究报告》附下载丨三叠云

数字化时代已来&#xff0c;数字化办公工具 已成为企业数字化转型发展的基座 从思维理念到工具创新&#xff0c;办公从原来的物理空间走向现代化无边界的“云端” 数字化办公突破传统信息存储、挖掘、交互的藩篱&#xff0c;最终实现“办公协同” 需求与挑战并存&#xff0c…

数据结构——克鲁斯卡尔(Kruskal)算法

克鲁斯卡尔算法是求连通网的最小生成树的另一种方法。与普里姆算法不同&#xff0c;它的时间复杂度为O&#xff08;eloge&#xff09;&#xff08;e为边数&#xff09;&#xff0c;适合于求边稀疏的网的最小生成树 。克鲁斯卡尔算法从另一途径求网的最小生成树。其基本思想是&a…

疫情下的思考:全球疫情带来的危机与机遇

目录 敬重天道&#xff0c;敬重万物&#xff0c;这也许是化解危机的根源。 共同体的优势在于分工协作降低成本&#xff1b;劣势在于复杂性加深&#xff0c;脆弱不堪。 何为共同体&#xff1f; 危机四伏:社会整体运行的复杂性、机动性和动物性危机。 复杂性:疫情其实是在对…

力扣算法入门刷题

1、回文数 判断输入的整数是否是回文 我的一般思路&#xff1a; 将输入的整数转成字符串&#xff0c;再将这个字符串转成字符数组c&#xff0c;对字符数组进行遍历&#xff0c;如果第i个元素与第 c.length - i - 1 元素不相等&#xff0c;也就是通过比较首尾元素是否相同来判断…

D. Permutation Addicts(构造)

纯思维的1900构造还是有些顶&#xff0c;而且全球场和div12感觉还是没有难度分数通胀的&#xff0c;同等的分数全球场的题质量明显高一些。 D. Permutation Addicts 题意&#xff1a; 我们给定一个长度为n的排列a&#xff0c;我们通过a按照如下方法去构造一个数组b。 确定某…

目标检测算法——YOLOv5/YOLOv7改进之结合GAMAttention

关注”PandaCVer“公众号 深度学习Tricks&#xff0c;第一时间送达 目录 超越CBAM&#xff0c;全新注意力GAM&#xff1a;不计成本提高精度&#xff01; &#xff08;一&#xff09;前沿介绍 1.GAM结构图 2.相关实验结果 &#xff08;二&#xff09;YOLOv5/YOLOv7改进之结…

景联文科技:车企如何解决自动驾驶数据标注难题?

“AI数据是人工智能行业的燃料&#xff0c;对自动驾驶领域头部企业来说&#xff0c;为了保持自身的竞争优势并加快自动驾驶应用安全落地进程&#xff0c;需要依靠大量的高质量标注数据做支撑&#xff0c;才能有效解决自动驾驶深度学习理论上遇到的问题。数据作为AI技术的底层基…

中国天然气除湿装置行业市场调研报告

目前&#xff0c;世界上除湿机的主要产地集中在意大利、日本、中国和中国台湾省等。中国在全球除湿机市场上的地位越来越突出&#xff0c;全球80%以上的除湿机产自中国。我国除湿机行业内销和出口严重分化&#xff0c;表现为内销不足&#xff0c;出口过多。作为制冷行业的一个小…

自然语言生成技术现状调查:核心任务、应用和评估(1)

论文&#xff1a;《Survey of the State of the Art in Natural Language Generation: Core tasks, applications and evaluation》 Journal of Artificial Intelligence Research 61 (2018) 65-170 Submitted 02/17; published 01/18 2018年的论文&#xff08;live-5477-103…

【计算机网络】linux网络相关常用命令

性能指标有哪些&#xff1f; 带宽&#xff1a;链路的最大传输速率&#xff08;b/s&#xff09;吞吐率&#xff1a;单位时间内成功传输的数据量时延&#xff1a;表示请求数据包发送后&#xff0c;收到对端响应&#xff0c;所需要的时间延迟。PPS&#xff0c;每秒网络包发送数量…

大学生HTML作业节日网页 HTML作业节日文化网页期末作业 html+css+js节日网页 HTML学生节日介绍 HTML学生作业网页视频

&#x1f389;精彩专栏推荐 &#x1f4ad;文末获取联系 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业&#xff1a; 【&#x1f4da;毕设项目精品实战案例 (10…