LeetCode 第17题:电话号码的字母组合

news/2025/2/11 21:47:44/文章来源:https://www.cnblogs.com/lavender-vv/p/18710527

LeetCode 第17题:电话号码的字母组合

题目描述

给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。

给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

  • 2: abc
  • 3: def
  • 4: ghi
  • 5: jkl
  • 6: mno
  • 7: pqrs
  • 8: tuv
  • 9: wxyz

难度

中等

题目链接

https://leetcode.cn/problems/letter-combinations-of-a-phone-number/

示例

示例 1:

输入:digits = "23"
输出:["ad","ae","af","bd","be","bf","cd","ce","cf"]

示例 2:

输入:digits = ""
输出:[]

示例 3:

输入:digits = "2"
输出:["a","b","c"]

提示

  • 0 <= digits.length <= 4
  • digits[i] 是范围 ['2', '9'] 的一个数字。

解题思路

方法:回溯(深度优先搜索)

这道题可以使用回溯法求解。对于每个数字,我们需要尝试它对应的每个字母,然后继续处理下一个数字。

关键点:

  1. 建立数字到字母的映射表
  2. 使用回溯法遍历所有可能的组合
  3. 使用StringBuilder优化字符串拼接
  4. 处理空字符串的特殊情况

具体步骤:

  1. 处理特殊情况(空字符串)
  2. 初始化数字到字母的映射
  3. 使用回溯法:
    • 当前组合长度等于输入长度时,添加到结果
    • 否则,遍历当前数字对应的所有字母
    • 递归处理下一个数字
    • 回溯,删除最后添加的字母

时间复杂度:O(4^N × N),其中N是输入的长度
空间复杂度:O(N),递归深度

代码实现

C# 实现

public class Solution {private readonly string[] phoneMap = {"",     // 0"",     // 1"abc",  // 2"def",  // 3"ghi",  // 4"jkl",  // 5"mno",  // 6"pqrs", // 7"tuv",  // 8"wxyz"  // 9};public IList<string> LetterCombinations(string digits) {List<string> result = new List<string>();// 处理空字符串if (string.IsNullOrEmpty(digits)) {return result;}// 使用StringBuilder优化字符串拼接StringBuilder current = new StringBuilder();Backtrack(digits, 0, current, result);return result;}private void Backtrack(string digits, int index, StringBuilder current, List<string> result) {// 如果当前组合长度等于输入长度,添加到结果if (index == digits.Length) {result.Add(current.ToString());return;}// 获取当前数字对应的字母string letters = phoneMap[digits[index] - '0'];// 遍历当前数字对应的所有字母for (int i = 0; i < letters.Length; i++) {// 添加当前字母current.Append(letters[i]);// 递归处理下一个数字Backtrack(digits, index + 1, current, result);// 回溯,删除最后添加的字母current.Length--;}}
}

优化版本(使用队列)

public class Solution {private readonly string[] phoneMap = {"",     // 0"",     // 1"abc",  // 2"def",  // 3"ghi",  // 4"jkl",  // 5"mno",  // 6"pqrs", // 7"tuv",  // 8"wxyz"  // 9};public IList<string> LetterCombinations(string digits) {List<string> result = new List<string>();// 处理空字符串if (string.IsNullOrEmpty(digits)) {return result;}// 初始化结果为空字符串result.Add("");// 逐个处理每个数字foreach (char digit in digits) {List<string> temp = new List<string>();string letters = phoneMap[digit - '0'];// 将当前数字的每个字母与之前的结果组合foreach (string s in result) {foreach (char letter in letters) {temp.Add(s + letter);}}result = temp;}return result;}
}

代码详解

回溯版本:

  1. 映射表定义:
    • 使用字符串数组存储数字到字母的映射
  2. 回溯函数:
    • 使用StringBuilder优化字符串操作
    • 递归处理每个数字对应的字母
    • 使用index跟踪处理位置
  3. 结果收集:
    • 当处理完所有数字时添加结果
    • 回溯时删除最后添加的字母

队列版本:

  1. 迭代处理:
    • 逐个处理每个数字
    • 使用临时列表存储新的组合
  2. 组合生成:
    • 将当前数字的每个字母与之前的结果组合
    • 更新结果列表
  3. 优化:
    • 避免使用递归
    • 减少内存使用

执行结果

回溯版本:

  • 执行用时:132 ms
  • 内存消耗:42.8 MB

队列版本:

  • 执行用时:124 ms
  • 内存消耗:42.5 MB

总结与反思

  1. 这道题的关键点:
    • 理解回溯法的应用
    • 字符串组合的生成
    • 优化字符串操作
  2. 两种解法比较:
    • 回溯法:思路清晰,适合扩展
    • 队列法:性能更好,代码更简洁
  3. 优化思路:
    • 使用StringBuilder提高性能
    • 预分配结果集大小
    • 考虑并行处理大规模输入

相关题目

  • LeetCode 第22题:括号生成
  • LeetCode 第39题:组合总和
  • LeetCode 第46题:全排列
  • LeetCode 第78题:子集

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

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

相关文章

最近,测试的招聘市场已经疯掉了…

这是我入行测试的第1007天,门槛低,技术难度不高,食物链最底端。出现严重的bug,首先背锅的就是测试...📝 博主首页 : 「码上生花」 ,同名公众号 :「伤心的辣条」📝 面试求职: 「面试试题小程序」 ,内容涵盖 测试基础、Linux操作系统、MySQL数据库、Web功能测试、接口…

P1083 [NOIP 2012 提高组] 借教室(差分)

说实话竟然没想到还能这样差分,这道题我们需要二分查找m个订单,对于每次二分用一次差分,然后看如果只考虑1到mid个订单是否会出现教室不够用的情况,如果够用说明导致教室不够用的订单在后面,应该让begin=mid+1;反之让end-1;其实这道题就是让我们找第一个出现教室不够用的…

来吃糖

先放犯错后 be like:1 return // 倍增求 lca int bfs(int x) {queue<int> q;q.push(x);dep[x] = 1;while (q.size()) {x = q.front(), q.pop();for (auto it : G[x]) {int y = it.first, z = it.second;if (dep[y]) continue;dep[y] = dep[x] + 1;d[0][y] = z;f[0][y] =…

P9330 [JOISC 2023] JOI 国的节日 2 题解

Description 对于以下问题:给定长度为 \(n\) 的序列 \(a\)、\(b\),满足以下条件:在序列 \(a\) 与序列 \(b\) 中,\(1\) 到 \(2n\) 的整数各出现恰好一次; 对于 \(1\leq i\leq n\),\(a_i<b_i\); 对于 \(1\leq i<n\),\(a_i<a_{i+1}\)。求:最多能在 \([a_i,b_i]\…

一站式合同自动化:飞书审批与腾讯电子签的完美融合

Z国际教育中心专注于将全球顶尖教育资源引入中国,通过本地化整合与优化,将这些优质资源转化为中国青年触手可及的学习机会。我们的使命是帮助学生培养深厚的家国情怀与开阔的国际视野,助力他们成长为未来社会的栋梁之才。 遇到的问题 1. 业务种类多,合同审批繁琐 通过飞书平…

Linux下Docker及Nvidia Container ToolKit安装教程

作者:SkyXZ CSDN:SkyXZ~-CSDN博客 博客园:SkyXZ - 博客园 我们接下来在Ubuntu中安装Docker(安装详见:Get Docker | Docker Docs)及NVIDIA Container Toolkit(安装详见:Installing the NVIDIA Container Toolkit — NVIDIA Container Toolkit 1.17.3 documentat…

在用 uni-app 开发钉钉小程序的时候遇到一个奇怪的问题,发送请求拿不到返回的数据

今天我一位同事说用 uni-app 新开发的钉钉小程序里发送请求拿不到返回的数据,看了下发现调试工具的“Network”栏里显示请求是发送成功的,也有返回数据,但是没触发请求的回调函数。 原本用的是 luch-request 这个库发送的请求,后来试了下 uni-app 内置的 uni.request 以及钉…

15. 进程处理

一、什么是进程进程(Process)是正在运行的程序,是操作系统进行资源分配的基本单位。程序是存储在硬盘或内存的一段二进制序列,是静态的,而进程是动态的。每个进程都由自己的地址空间、代码段、数据段以及分配给它的其它系统资源(如文件描述符、网络连接等)。 二、创建子…

我把deepseek等大模型接入了微信公众号,打造个人AI助手

我把deepseek等大模型接入了微信公众号,打造个人AI助手前言 最近deepseek大模型可是火出了圈,给国产大模型公司点赞。于是乎去deepseek试了一下效果,奈何太多人使用了,问两句来一句 “服务器繁忙,请稍后再试”,体验感实在太差了。 作为程序员,怎么能忍受?于是乎去寻找d…

(未解决)word中插入pdf图片(高清、矢量图)

(未解决)word中插入pdf图片(高清、矢量图) 1.个人诉求: pdf高清矢量格式的图片,插入至word中 2.尝试的解决方法: https://blog.csdn.net/weixin_45399376/article/details/115281547?spm=1001.2014.3001.5502。 3.具体操作步骤: 1)word——插入——对象——文件中的文…

一语总结

一语总结 真心建议把找到的一些性质和做法以文字形式写下来,当掉不过样例的时候一个一个检查其正确性。”P9169 [省选联考 2023] 过河卒“用DFS将环当作平局是错误的因为这可能只是一个不优的必胜/必败局面,正确的做法是老实建图按拓扑序跑BFS。就这个结论的错误害我虚空调题…

软考高级《系统架构设计师》知识点(二)

操作系统知识 操作系统概述操作系统定义:能有效地组织和管理系统中的各种软/硬件资源,合理地组织计算机系统工作流程,控制程序的执行,并且向用户提供一个良好的工作环境和友好的接口。 操作系统有三个重要的作用:管理计算机中运行的程序和分配各种软硬件资源; 为用户提供…