Leetcode 17 电话号码的字母组合 学习感悟

思路:

首先提前存好要用的nums参考表,为了让字符串中的数字与参考表下标一致,01可以存无用信息

整个核心思想就是递归,如" 234 "数字  [ int ip = str.at(0) - '0'; 获取vector中的下标]

第一层"234"拿到2的数字,2对应abc,因此有nums[ip].size()次循环 ,首循环pushstr="a"【拿str首字母,递归下去str少首字母】

           第二层"34"拿到3的数字,3的对应def ,因此有nums[ip].size()次循环,首循环pushstr="ad"

                           第三层"4"拿到数字4,对应ghi,因此有nums[ip].size()次循环,首循环pushstr="adg"

                                            第四层" "没拿到数字空,因此保存了adg,res.push_back(pushstr);

                            回到了第三层,此时adg中的g已经使用了,所以pushstr.pop_back();  //将g字母吐了

                            开始第二次循环,拿到了h,次循环pushstr="adh".........

整个递归过程如下

# include<iostream>
# include<vector>
# include<string>
# include<algorithm>
# include<math.h>
# include<climits>
using namespace std;
void preVector(vector<string>& nums) {
	nums.push_back("!!!");//0
	nums.push_back("!!!");//1
	nums.push_back("abc");//2
	nums.push_back("def");
	nums.push_back("ghi");
	nums.push_back("jkl");
	nums.push_back("mno");
	nums.push_back("pqrs");
	nums.push_back("tuv");
	nums.push_back("wxyz");//9
}
void Combinations(string& str,string &pushstr, vector<string>& nums, vector<string>& res) {//参考组 ,结果组
	//用递归
	if (str.empty()) { 
		if (pushstr.empty()) {//双空
			return;
		}
		res.push_back(pushstr);
		return;
	}//空串结束
	int ip = str.at(0) - '0';//串第一个数字对应的表中的下表,如2,对应vector下标2的表
	string newstr;
	for (int i = 0; i < nums[ip].size(); i++) {
		pushstr += nums[ip].at(i);
		newstr = str.substr(1, str.size() - 1);
		Combinations(newstr, pushstr, nums, res);
		pushstr.pop_back();//将下一层输出的字母吐了
	}
}
vector<string> letterCombinations(string digits) {
	vector<string>nums;
	vector<string>res;
	string str,pushstr;
	preVector(nums);
	pushstr = "";
	Combinations(digits, pushstr, nums, res);
	return res;
}
int main(void) {
	vector<string>res;
	res = letterCombinations("");
	int i = 0;
	while (i < res.size()) {
		cout << res[i++] << endl;
	}
	return  0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是电话号码字母组合问题的 C++ 代码实现: ``` class Solution { public: vector<string> letterCombinations(string digits) { unordered_map<char, string> mapping = { {'2', "abc"}, {'3', "def"}, {'4', "ghi"}, {'5', "jkl"}, {'6', "mno"}, {'7', "pqrs"}, {'8', "tuv"}, {'9', "wxyz"} }; vector<string> res; if (digits.empty()) { return res; } string combination; backtrack(res, combination, digits, 0, mapping); return res; } void backtrack(vector<string>& res, string& combination, string& digits, int index, unordered_map<char, string>& mapping) { if (index == digits.size()) { res.push_back(combination); return; } for (char c : mapping[digits[index]]) { combination.push_back(c); backtrack(res, combination, digits, index + 1, mapping); combination.pop_back(); } } }; ``` 其中 `letterCombinations` 函数用来生成所有的字母组合,`backtrack` 函数用来进行回溯操作。在 `letterCombinations` 函数中,首先根据数字字符和字母的映射关系创建了一个 `unordered_map` 对象 `mapping`。然后定义了一个空字符串 `combination` 和一个空 vector `res` 来保存最终结果。最后调用了 `backtrack` 函数来生成所有的字母组合。在 `backtrack` 函数中,首先判断是否达到了数字字符串的末尾,如果是,则将当前的 `combination` 字符串保存到 `res` 中。否则,遍历当前数字字符所能表示的所有字母,依次加入到 `combination` 字符串中,然后递归调用 `backtrack` 函数,添加下一个数字字符所能表示的字母。递归完成后,需要将 `combination` 字符串还原到上一个状态,以便进行下一次回溯。最终返回 `res` 数组即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值