Leetcode:电话号码的字母组合

题目链接: 17. 电话号码的字母组合 - 力扣(LeetCode)

普通版本(回溯)

cpp 复制代码
class Solution {
public:
    string tmp;//临时存放尾插内容
    vector<string> res;//将尾插好的字符串成组尾插给res
    vector<string> board={"","","abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"};//为了使得num与字符串在数组中的位置相对应
    //数字2对应的字符串应该board数组中的下标为2的字符串,即"abc"
    //数字3对应的字符串应该board数组中的下标为3的字符串,即"def"
    //数字4对应的字符串应该board数组中的下标为4的字符串,即"ghi"
    //...

    //pos用于记录是否遍历完整个digits字符串
    void DFS(int pos,string digits)//深度优先遍历
    {
        if(pos==digits.size())//整个字符串遍历完后就退出
        {
            res.push_back(tmp);
            return;
        }
        
        int num=digits[pos]-'0';//用字符串转整数的方式获取digit中的各个数字

        for(int i=0;i<board[num].size();i++)
        {
            tmp.push_back(board[num][i]);
            DFS(pos+1,digits);
            tmp.pop_back();//尾删,只删除一个
        }
    }


    vector<string> letterCombinations(string digits) 
    {
        if(digits.size()==0) 
        {
            return res;
        }
        DFS(0,digits);
        return res;
    }
};

优化版本(待补充)

~over~

相关推荐
guitarCC2 分钟前
【裁员感想】
职场和发展
所以遗憾是什么呢?13 分钟前
扩展欧几里得算法【Exgcd】的内容与题目应用
数学·算法·数论·扩展欧几里得·exgcd
haaaaaaarry17 分钟前
【贪心】C++ 活动安排问题
开发语言·c++·算法·贪心
ChengZUOZZZ32 分钟前
蓝桥杯题目:二维前缀和
java·算法·蓝桥杯
槐月杰5 小时前
C语言中冒泡排序和快速排序的区别
c语言·算法·排序算法
笺上山河梦7 小时前
文件操作(二进制文件)
开发语言·c++·学习·算法
大慕慕好懒7 小时前
PHP弱类型hash比较缺陷
算法·哈希算法
snowfoootball8 小时前
最短路问题
数据结构·算法
有你的冬天1989 小时前
数据结构(一)
数据结构·算法
满怀10159 小时前
【Python进阶】列表:全面解析与实战指南
python·算法