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

房地产免费网站建设镇江有几个区

房地产免费网站建设,镇江有几个区,宝宝发烧反反复复什么原因导致的,怎么把网站和域名绑定在我们的座机上,都有这种数字与字母对应的按键。 以此为例,讲解多叉树的深度优先遍历 问题 给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。 给出数字到字母的映射如下(与电话按键相同…

在我们的座机上,都有这种数字与字母对应的按键。

以此为例,讲解多叉树的深度优先遍历

问题

给定一个仅包含数字 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'] 的一个数字。

分析

假设我们输入的是 2 5 8 那么对应元素分别是abc jkl tuv。一共有3*3*3 = 27钟组合。我们的思路是

先从2中取a,再从5中取j,再从8中取t。将三个字母存放到一个字符串中。再将不断组合好的字符串push_back到vector<string>中

完成好一组之后,到达最深再返回,再组合a j u;再push_back。

代码

class Solution {
private:const char* numStrArr[10]= {"","","abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"};   //存放字符串的数组public:void Combine(const string& digits, int i, string combineStr,vector<string>& ret){if (i == digits.size())     //深度遍历{ret.push_back(combineStr);return;}int num = digits[i] - '0';string str =numStrArr[num];    //数字映射的字母for (auto ch : str)     //取一个字符,去排列组合{Combine(digits,i+1,combineStr+ch,ret);}}vector<string> letterCombinations(string digits) {vector<string> v;   //存放字符串组合string str; if (digits.empty())return v;Combine(digits,0, str,v);return v;}
};

几个对象的功能digits,0, str,v

digits:存储输入的字符串

0:作为下标,不断遍历字符串,知道到达size()为止

str:将映射好的数据存储到str中

v:返回数组

核心代码

string str =numStrArr[num];    //数字映射的字母

        for (auto ch : str)     //取一个字符,去排列组合

        {

            Combine(digits,i+1,combineStr+ch,ret);

        }

假设还是 2 5 8 。取到2的首字母之后,进入递归,取5的首字母。继续递归取到8的首字母。

再push_back

回到循环,继续取8的第二个字母

等到5的首字母取完之后,再取5的第二个字母,继续递归。

剖解代码

通过上述的分析,我们可以得出,

1.需要靠一个递归完成遍历。递归的返回条件是深度达到size()

2.既然是数字与字母的映射,那就需要借助下标去不断遍历读取到的字符串 

3.在不断加深的过程中,应该靠的是 + 而不是+=,这样return之后,就可以回到原来的字符串

经验总结

当我们直接上手,可能不会那么容易。但是显然的是,这是存放在容器中的数据。因此理所应到要去考虑到用什么类型的数据结构去存放数据。从而想到该用什么方式去遍历。

对于树,最好的方法就是递归遍历(想好返回条件)。

其次:

1.最终要的是,递归要分析好return条件

2.当需要深度遍历时,一般需要借助下标 i

3.用到的是+ 而不是+=

http://www.yayakq.cn/news/65228/

相关文章:

  • 中国品牌网站官网邢台兼职网站有哪些?
  • word超链接网站怎样做海誉网站定制
  • 怎么向企业推销网站建设石家庄做网站百度推广
  • 大学什么专业做网站海天网站建设
  • 吴中区网站建设技术建设工程公司名字
  • 建立一个公司自己的网站平台网站建设
  • 品牌型网站开发公司网站建设多少费用济南兴田德润评价
  • 网站改版介绍创建网站平台要多少钱
  • 网站首页浮动广告怎么做常州外贸人才网
  • 免费建网站空间邢台建站
  • 昆明网站建设优化企业国信网络模版网站建设方案相关
  • 自考大型网站开发工具asp.net网站恢复
  • 济南免费做网站网站建设服务58
  • 本机做网站服务上传到网站建设合同 文库
  • edge网页视频怎么下载seo外链群发网站
  • 怎样优古网络公司网站后台域名抢注网站是怎么
  • C 建设个人网站做网站好接活吗
  • 福建省建设执业注册资格管理中心网站凡客诚品倒闭了吗知乎
  • 本地成都网站建设网站创作思路
  • 1v1网站建设专门做期货的网站
  • wordpress做图片站国内哪家网站做的系统纯净
  • 网站内网页标题对百度排名在哪家网站做推广好
  • 徐州建筑网站著名的响应式网站有哪些
  • 推广网站的几种方法wordpress free
  • 网站为什么上传不了图片北京南站附近的景点
  • 成都微网站设计个人博客网站设计
  • 沈阳做企业网站哪家好物流网站建设费用
  • 做安全防护信息的网站网页版梦幻西游科举答案
  • 上海网站建设高端赣楠脐橙网络营销推广方式
  • 门户站点是什么百度域名注册流程