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

辽宁建设厅规划设计网站西安网络推广运营公司

辽宁建设厅规划设计网站,西安网络推广运营公司,网络公司是做什么,无锡建站方案题目 17. 电话号码的字母组合 中等 相关标签 哈希表 字符串 回溯 给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。 给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。…

题目

17. 电话号码的字母组合

中等

相关标签

哈希表   字符串   回溯

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

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

示例 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. 代码首先定义了一个常量数组 letterMap,其中每个元素表示数字0-9对应的字符集合。这样,我们可以通过数字来索引 letterMap 中的元素,得到对应的字符集合。
  2. 接下来,代码定义了两个成员变量 anss,分别用于存储最终的答案集合和临时的组合结果。
  3. 然后,代码定义了一个递归函数 backtracking,该函数通过参数 digitsindex 来表示当前处理的数字串和目前处理到的位置。
  4. backtracking 函数中,当 index 等于 digits 的大小时,说明已经找到了一种组合,将 s 加入到答案集合 ans 中,并返回。
  5. 否则,获取当前位置的数字 digit,以及它对应的字符集合 letters
  6. 接下来,通过循环遍历当前数字对应的每个字符,并将其依次加入到临时组合结果字符串 s 中。
  7. 然后,递归调用 backtracking 函数处理下一个数字的字母组合。
  8. 最后,在完成递归调用后,进行回溯操作,将刚才加入的字符移出,继续尝试下一个字符。
  9. 在主函数 letterCombinations 中,首先清空临时字符串 s 和答案集合 ans
  10. 然后,判断输入的数字串是否为空,如果为空,直接返回空的答案集合。
  11. 否则,调用 backtracking 函数开始搜索字母组合。
  12. 最后,返回最终的答案集合。

复杂度

        时间复杂度:

                O(3m×4n)

算法的时间复杂度为 O(3m×4n),其中 m 表示输入数字串中对应字母集合大小为 3 的数字个数,n 表示输入数字串中对应字母集合大小为 4 的数字个数。因为一般情况下一个数字对应 3 个字母,另外两个数字对应 4 个字母,所以总的时间复杂度为 O(3m×4n)。

        空间复杂度

                O(m+n)

空间复杂度为 O(m+n),即递归栈的深度。在最坏情况下,所有数字都对应字母集合大小为 4,所以根据上面的时间复杂度分析,有 m+n 个数字需要进行搜索,因此栈的深度也为 m+n,所以空间复杂度为 O(m+n)。

c++ 代码

class Solution {
public:const string letterMap[10]={"",       // 数字0对应的字母为空字符串,因为通常没有字母对应数字0"",       // 数字1对应的字母为空字符串,因为通常没有字母对应数字1"abc",    // 数字2对应的字母为abc"def",    // 数字3对应的字母为def"ghi",    // 数字4对应的字母为ghi"jkl",    // 数字5对应的字母为jkl"mno",    // 数字6对应的字母为mno"pqrs",   // 数字7对应的字母为pqrs"tuv",    // 数字8对应的字母为tuv"wxyz"    // 数字9对应的字母为wxyz};vector<string> ans;  // 存储最终的答案集合string s;            // 用于临时存储每个组合结果的字符串void backtracking(string &digits,int index){if(index == digits.size())  // 如果达到了数字串的末尾,说明已经找到了一种组合,将其加入到答案集合中{ans.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();   // 清空临时字符串sans.clear();  // 清空答案集合ansif(digits.size() == 0)  // 如果输入的数字串为空,则直接返回空的答案集合{return ans;}backtracking(digits,0);  // 开始回溯搜索字母组合return ans;  // 返回最终的答案集合}
};

觉得有用的话可以点点赞,支持一下。

如果愿意的话关注一下。会对你有更多的帮助。

每天都会不定时更新哦  >人<  。

http://www.hkea.cn/news/404959/

相关文章:

  • 做简报的网站广州搜发网络科技有限公司
  • 南乐县住房和城乡建设局网站制作网站的步骤是什么
  • 金华做网站最专业的公司搜易网提供的技术服务
  • wordpress适合门户网站吗怎么营销自己的产品
  • 常用的网站类型有哪些seo优化专员编辑
  • 网站专题框架怎么做海阳seo排名
  • 手机网站代码下载黄页网站推广服务
  • 做网站前端多少钱在线bt种子
  • wordpress+模版+推荐专业网站seo推广
  • 浦项建设公司员工网站2023免费推广入口
  • 如何查询某个网站的设计公司最新推广注册app拿佣金
  • 八宝山做网站公司打广告
  • wordpress vip查看插件南宁seo费用服务
  • 建站之星模板怎么设置手机如何做网站
  • 上海公司网站制作价格西安百度关键词排名服务
  • 长沙网页制作开发公司aso优化方案
  • 深圳罗湖网站制作成人电脑基础培训班
  • 无锡网站制作咨询深圳网站设计十年乐云seo
  • 大连城市建设网站seo优化顾问服务阿亮
  • 福州 网站建设沈阳seo关键词排名优化软件
  • 做网站还要买服务器吗镇江seo
  • 专门做特价的网站优化排名案例
  • 网站建设的一些问题友链交易交易平台
  • 创业初期要建立公司的网站吗seo排名优化代理
  • 做网站全屏尺寸是多少钱站长工具查询系统
  • 做企业平台的网站有哪些手机网站制作教程
  • 免费行情的软件大全下载北京公司排名seo
  • 网站联系方式要素qq群推广链接
  • div css 网站模板免费的云服务器有哪些
  • 35互联做网站好吗网店运营工作内容