C++ 之LeetCode刷题记录(三十六)

😄😊😆😃😄😊😆😃

开始cpp刷题之旅。

目标:执行用时击败90%以上使用 C++ 的用户。

17. 电话号码的字母组合

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

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

示例 1:

输入:digits = "23"

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

示例 2:

输入:digits = ""

输出:[]

示例 3:

输入:digits = "2"

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

解题:

借代码随想录的一张图,这题目的意思大概就是如下这样的。

几个数字就有几层。

我们要收集的结果,就是["ad", "ae", "af", "bd", "be", "bf", "cd", "ce", "cf"]

对与n个不定的for循环,我们可以采用回溯。

如"23",先推入2中的a,再将3中的d、e、f推推入结果中,要不断的推入、保存、删除,

当取完3中的字符,再取出字符a,再推入字符b,再重复同样的动作。到2中的字符取完为止。

bash 复制代码
class Solution {
public:
    vector<string>str;
    string s;
	//定义string类型数组,将0和1没有字符的数字表示为空字符。
    const string letterMap[10] = {
        "", // 0
        "", // 1
        "abc", // 2
        "def", // 3
        "ghi", // 4
        "jkl", // 5
        "mno", // 6
        "pqrs", // 7
        "tuv", // 8
        "wxyz", // 9
    };
    void backtracking(const string& digits, int index){
        if(digits.size()==index){
            str.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) {
        if (digits.size() == 0) {
            return str;
        }
        backtracking(digits,0);
        return str;
    }
};

提交记录:

相关推荐
zh_xuan2 小时前
c++ 单例模式
开发语言·c++·单例模式
利刃大大5 小时前
【在线五子棋对战】二、websocket && 服务器搭建
服务器·c++·websocket·网络协议·项目
喜欢吃燃面5 小时前
C++刷题:日期模拟(1)
c++·学习·算法
SHERlocked935 小时前
CPP 从 0 到 1 完成一个支持 future/promise 的 Windows 异步串口通信库
c++·算法·promise
_Itachi__5 小时前
LeetCode 热题 100 74. 搜索二维矩阵
算法·leetcode·矩阵
虚拟之6 小时前
36、stringstream
c++
我很好我还能学6 小时前
【面试篇 9】c++生成可执行文件的四个步骤、悬挂指针、define和const区别、c++定义和声明、将引用作为返回值的好处、类的四个缺省函数
开发语言·c++
chao_7897 小时前
链表题解——两两交换链表中的节点【LeetCode】
数据结构·python·leetcode·链表
南岩亦凛汀7 小时前
在Linux下使用wxWidgets进行跨平台GUI开发
c++·跨平台·gui·开源框架·工程实战教程
曦月逸霜7 小时前
第34次CCF-CSP认证真题解析(目标300分做法)
数据结构·c++·算法