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

杭州网站建设公司排名seo网站推广招聘

杭州网站建设公司排名,seo网站推广招聘,万能网站,邯郸楼盘最新信息网一、题目描述给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。示例 1:输入:digits "23"输出…

一、题目描述

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

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

示例 1:

输入:digits = "23"

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

示例 2:

输入:digits = ""

输出:[]

示例 3:

输入:digits = "2"

输出:["a","b","c"]

来源:力扣(LeetCode)

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

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

二、运行结果

三、解题思路

这里是参考官方给出的解题思路,本人想的也是用回溯法,但是奈何不懂回溯怎么写org,仅以此博文记录,权当加深理解。

首先用一个哈希表将每个数字对应的字母串,然后进行回溯遍历,具体如下:

如果当前字母组合的长度和原数字串的长度相等,则表示已经得到了一个满足的字母组合,将该字母串加入到结果列表中;(递归出口)

如果不相等,表示还没有遍历完数字串,则取出当前下标的数字,根据数字从哈希表中取出其对应的字母串,获取这个字母串的长度(字母个数),然后对这个字母串的每个字母进行处理:

首先出去该字母,然后将该字母加入到作为参数传递的字母串后面,再递归对下一个数字进行同样的处理,最后是回溯(将当前字母从字母串中删除,避免重复遍历)。

ps: 回溯是通过递归实现的,所以最前面要定义递归出口,最重要的是在要在递归后面删掉当前字母,这就是回溯。

四、AC代码

class Solution {public List<String> letterCombinations(String digits) {int len = digits.length();List<String> ans = new ArrayList<>();if(len == 0) return ans;//双花括号初始化 匿名内部类 初始化块Map<Character, String> numMap = new HashMap<>(){{put('2', "abc");put('3', "def");put('4', "ghi");put('5', "jkl");put('6', "mno");put('7', "pqrs");put('8', "tuv");put('9', "wxyz");}};StringBuffer sb = new StringBuffer();trackback(digits, numMap, ans, 0, sb);return ans;}//回溯(用递归的方式实现)public void trackback(String digits, Map<Character, String> phoneMap, List<String> ans, int index, StringBuffer sb){if(index == digits.length()){ans.add(sb.toString());} else {char num = digits.charAt(index);String letters = phoneMap.get(num); //当前数字对应的字母串int letCount = letters.length(); //当前数字对应的字母个数for(int i=0; i<letCount; ++i){char c = letters.charAt(i);sb.append(c);  //加入当前字母trackback(digits, phoneMap, ans, index+1, sb);  //递归处理下一个数字sb.deleteCharAt(index); //回溯}}}
}
http://www.mmbaike.com/news/100621.html

相关文章:

  • 百度网站考核期腾讯广告代理
  • 中国洛阳网seo排名是什么意思
  • 魔都网站建设世界球队最新排名
  • 有没有教做韩餐的网站厦门seo排名扣费
  • 做网站1200百度小说搜索风云榜排行榜
  • 搜索引擎优化人员优化seo导航站
  • 网站做移动适配以后可以取消吗泉州排名推广
  • 网站设计公司收费标准谷歌seo和百度区别
  • 企业网站里面的qq咨询怎么做安徽企业网站建设
  • 用什么软件做网站最简单网站排名优化客服
  • 许昌哪里做网站wordpress官网入口
  • 福安网站建设淘宝店铺推广方法
  • txt做网站 插入图片自媒体培训
  • 最近下载的网站怎么找如何建造自己的网站
  • 企业公司动态网站设计与实现重庆疫情最新数据
  • 淘宝网站是哪个公司做的今日国际新闻头条15条
  • 网站着陆页有多少个东莞整站优化
  • 新乡商城网站建设哪家专业竞价推广遇到恶意点击怎么办
  • 电商网站建设成本360优化大师软件
  • 网站建设的关键个人网站制作流程
  • 个人网站做淘宝客教程淘宝推广软件
  • 兴县做网站的公司seo公司优化方案
  • 青岛网站制作网站优化 seo和sem
  • app和网站开发哪个难百度客服24小时电话
  • 租用微信做拍卖网站技能培训机构排名前十
  • 室内装修3d动态演示效果图seo优化软件有哪些
  • 如何注册电商平台关键词优化的技巧
  • 动态视觉设计网站女生学电子商务后悔了
  • 你是什么做的测试网站优化设计答案五年级下册
  • 网站做app安全吗今日头条新闻视频