电话号码的字母组合 【C++】【力扣刷题】

server/2024/9/24 7:17:28/

 解题思路:

  • 以第一个为例,digits = “23”,表明从电话号码的按键中选取2和3这两个字符,然后去寻找它们各自所对应的字母,这里每一个数字字符所对应的字母的不同,0对应的是空字符,而1的话题目中讲到是不对应任何字母,要注意的是像7和9所对应的是4个字母。
  • 以上这些应该用一个数组或者容器将它们存起来。
  • 这里由于digits的个数是不确定的,所以我们没有办法使用多层for循环来嵌套求解。就需要用到递归,回溯的方式来解题。
  • 那么不难想象,这题应该是多叉树的递归并且保存数据到vector<string>容器中。
class Solution {
public:  vector<string> letterCombinations(string digits){}
};

 解题步骤:

        1.看题,传入一个string类的digits对象,里面是字符串.   返回值是vector<string>

所以我们应该创建一个vector<string>容器的对象 vector<string> statistics;

        2.我们需要把对应的关系映射到一维数组中,放到函数外面。

class Solution {
public:const char* numStrArr[10] = { "","","abc","def","ghi","jkl","mno","pqrs","tuv","wxyz" vector<string> letterCombinations(string digits){vector<string> statistics;//解题过程return statistics;}
};

    3.我们需要写一个子函数来完成递归操作。那我们需要传什么参数呢? 

        ①我们需要传接收型参数vector<string> statistics;

        ②需要传digits,来获取需要的字符

        ③需要传一个n,来计算深度 

        ④我们还需要能够保存字符串的string类对象

class Solution {
public:const char* numStrArr[10] = { "","","abc","def","ghi","jkl","mno","pqrs","tuv","wxyz" };void _letterCombinations(vector<string>& statistics, string str, int n, string& digits){}vector<string> letterCombinations(string digits){vector<string> statistics;string str;_letterCombinations(statistics, str, 0, digits);return statistics;}
};

    4. 我们需要写一个递归的返回条件

        当到了最深的层次时,先把字符串push_back到vector的容器中,然后回溯。

if (n == digits.size()){statistics.push_back(str);Static++;return;}

5.写执行过程:

int sz = digits[n] - 48;
string s1;
s1 = numStrArr[sz];
for (int i = 0; i < s1.size(); i++)
{char ch = s1[i];_letterCombinations(statistics, str + ch, n + 1, digits);
}

   过程

        1. sz记录数字,为了通过下标来映射字符串。

        2. 把字符串存储到string类里面,方便访问字符,ch=s1[i],记录字符

        3. 递归 

   我们为什么是采用+号,而不是+=呢?

        第一遍adg,然后存到vector<string> statistics对象中
        之后退到上一层,str=="ad",n==2,再递归,把adh存储起来。
        依次进行。

6.还差最后一步:

        有一个测试用例是我们就不能进入子函数。

vector<string> letterCombinations(string digits){vector<string> statistics;if(digits.size()==0) return statistics;//如果为空,就不进入子函数string str;_letterCombinations(statistics, str, 0, digits);return statistics;}

6.完整的代码:

class Solution {
public:const char* numStrArr[10] = { "","","abc","def","ghi","jkl","mno","pqrs","tuv","wxyz" };void _letterCombinations(vector<string>& statistics, string str, int n, string& digits){if (n == digits.size()){statistics.push_back(str);return;}int sz = digits[n] - 48;string s1;s1 = numStrArr[sz];for (int i = 0; i < s1.size(); i++){char ch = s1[i];_letterCombinations(statistics, str + ch, n + 1, digits);}}vector<string> letterCombinations(string digits){vector<string> statistics;if(digits.size()==0) return statistics;string str;_letterCombinations(statistics, str, 0, digits);return statistics;}
};


http://www.ppmy.cn/server/32126.html

相关文章

基于高德 API 的自动获取气候数据的 Python 脚本

文章目录 高德申请 Key脚本介绍运行结果示例 源代码&#xff1a; https://github.com/ma0513207162/PyPrecip。pyprecip\reading\read_api.py 路径下。 项目介绍&#xff1a;PyPrecip 是一个专注于气候数据处理的 Python 库&#xff0c;旨在为用户提供方便、高效的气候数据处理…

Java毕业设计 基于SSM SpringBoot vue宠物领养平台

Java毕业设计 基于SSM SpringBoot vue宠物领养平台 SSM 宠物领养平台 功能介绍 首页 图片轮播 新闻信息 新闻类型 新闻详情 宠物百科 宠物百科类型 宠物百科详情 宠物 宠物类型 宠物详情 立即领养 留言 论坛 发布帖子 登录 个人中心 宠物收藏 宠物领养订单 后台管理 登录注…

pycharm批量注释或取消多行

1. 背景和介绍 在我们编写Python代码的过程中&#xff0c;注释是非常重要的。它可以帮助我们理解代码的逻辑、功能和用法&#xff0c;并且方便其他开发者阅读和维护代码。然而&#xff0c;在大型项目中&#xff0c;有时需要批量注释或取消注释多行代码&#xff0c;手动操作会非…

SQL-索引篇整理

什么样的列适合建索引&#xff1f; 适合创建索引的列:主键、频繁进行范围检索的列、时常进行多表连接的列、数据量大的表,数据差异大的列。 索引优缺点 索引是数据库中用于提高数据检索性能的排好序的数据结构。它类似于书籍的目录&#xff0c;通过建立特定的数据结构将列或…

SDB2F5 首鼎1.2MHz 输入5V 输出28V 100mA升压DC-DC转换器

SDB2F5是一款固定频率&#xff0c;内部的软启动有很小脉冲电流可延长电池寿命。SDB2F5最低输入电压为2.5V&#xff0c;在输入电压为5V的时候可升压到28V 100mA。SDB2F5在轻负载时自动转成脉冲频率调制模式。SDB2F5有欠压锁定&#xff0c;限流和热过载保护。 特点&#xff1a; …

C# WinForm —— 12 ListBox绑定数据

ListBox加载大量数据时&#xff0c;避免窗体闪烁的方法&#xff1a; 在加载语句的前后分别加上 BeginUpdate()方法 和 EndUpdate()方法 指定一个集合为绑定的数据源 1. 首先&#xff0c;右键项目&#xff0c;添加类 2. 在新建的类文件中添加属性值信息 3. 构建初始化的对象…

零基础学习数据库SQL语句之操作表中数据的DML语句

我们的数据库是根据页面原型和相关需求完成相关开发的 在表中添加数据 删除数据 修改数据 添加数据 页面模型 当点击保存的时候就能将表单数据提交到服务端 服务端将数据添加到数据库 我们要用insert语句 将数据添加到数据库中 代码演示 CREATE DATABASE Dduo; USE Dduo…

40道Linux结业测试题,有解析,有答案

1.若root登录操作后的当前目录为&#xff1a;/usr/local&#xff0c;键入cd ~命令后&#xff0c;其当前目录变为&#xff08; &#xff09;。 A. /home/root B. /usr/local C. /root D. /home 2.如果当前目录为/home&#xff0c;进入目录/home/stu/test的命令是&#xff08; &a…