当前位置: 首页 > news >正文

力扣17题 电话号码的字母组合

 归类:回溯算法

回溯三部曲:

1.确定回溯函数参数

首先需要一个字符串s来收集叶子节点的结果,然后用一个字符串数组result来保存起来,这两个变量依然定义为全局。

参数指定是有题目中给的string  digits,然后还有一个参数就是int型的index。

index是用来记录遍历第几个数字了,就是用来遍历digits的,同时index也表示树的深度。

vector<string> result;
string s;
void backtracking(const string& digits, int index)

2.确定终止条件

叶子节点是用来收集的结果集,终止条件就是如果index等于输入的数字个数(digits.size)了,index是用来遍历digits的,然后收集结果,结束

本层递归。

if (index == digits.size()) {result.push_back(s);return;
}
3.确定单层遍历逻辑
首先取index指向的数字,并找到对应的字符集
然后for循环来处理这个字符集
int digit = digits[index] - '0';        // 将index指向的数字转为int
string letters = letterMap[digit];      // 取数字对应的字符集
for (int i = 0; i < letters.size(); i++) {s.push_back(letters[i]);            // 处理backtracking(digits, index + 1);    // 递归,注意index+1,一下层要处理下一个数字了s.pop_back();                       // 回溯
}
class Solution {
private:const string letterMap[10] = {"", // 0"", // 1"abc", // 2"def", // 3"ghi", // 4"jkl", // 5"mno", // 6"pqrs", // 7"tuv", // 8"wxyz", // 9};
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';        // 将index指向的数字转为intstring letters = letterMap[digit];      // 取数字对应的字符集for (int i = 0; i < letters.size(); i++) {s.push_back(letters[i]);            // 处理backtracking(digits, index + 1);    // 递归,注意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.zskr.cn/news/5421.html

相关文章:

  • 9.15更新linux命令
  • 萤火虫文旅年票、为何能成为撬动万亿文旅市场的利器
  • 详细介绍:C++(静态函数)
  • 2025.9.15日软件工程学习日志
  • 为什么不建议在 Docker 中跑 MySQL?
  • reLeetCode 热题 100-1 指针283. 移动零 - MKT
  • 解决c# DocX生成的word文档wps打开排版外边距错乱微软office正常问题
  • 机器视觉之图像处理篇 - 指南
  • if __name__ == __main__:
  • f-string用法
  • libdpi.dll libdatareport.dll libdash_plugin.dll libcurl-x86.dll libcurl-x64.dll libcurl_x64.dll - 指南
  • 理解 Kubernetes CSI
  • 利用RabbitMQ与Redis实现消息的延迟传递的策略
  • 实现我的第一个本地文档问答机器人
  • 关于32位单片机使用lwip无法访问(ping)外网,只能与同网段设备进行通信的问题解决
  • GoFrame框架查询数据表时对字段取别名
  • 离散数学课堂习题及课后习题 - PPX
  • Docker如何获取镜像
  • 偏移寻址
  • 黑客必备的DevOps实战工作坊:4小时动手实验指南
  • 金融业-数字化转型大赛-网络安全赛道部分wp
  • MySQL注意事项与规范 - 实践
  • 西电微机原理-第七章 常用接口器件
  • CF1264D1 Beautiful Bracket Sequence (easy version)
  • 西电微机原理-第六章 输入输出技术
  • c#给原文件重命名
  • 提升员工绩效的5大人才管理软件评测与分析
  • LLaVA- Improved Baselines with Visual Instruction Tuning - jack
  • Liunx 硬盘扩容
  • 基于WSL下载Hadoop和HBASE