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

Leetcode 17. 电话号码的字母组合 C++实现

Leetcode 17. 电话号码的字母组合

问题:给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

算法:递归嵌套,先获取 digits 长度 n ,如果为 0 则直接返回空数组。创建 path 数组,path 数组的单个位置的长度由 digits 长度 n 来决定,有几个数字,组合的字母就有几个。

进入 dfs 函数,如果 i==n ,即已经递归完 digits 数组中的所有数字了,则可以跳出函数返回。遍历数字所对应的字母,里面再嵌套数个遍历,遍历后续的数字所对应的字母。

代码:

class Solution {
    string MAPPING[10] = {"","","abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"};
    vector<string> ans;// 创建返回数组ans
public:
    vector<string> letterCombinations(string digits) {
        int n = digits.length();// 获取digits长度
        if(!n) return ans;// 为空则直接return
        string path(n,0);// path长度固定为n
        
        auto dfs = [&](auto&& dfs,int i){
            if(i == n){
                ans.emplace_back(path);// 把path存入数组末尾
                return;// i==n 证明后面已经没有数字了,可以跳出函数了
            }
            for(char c : MAPPING[digits[i] - '0']){// string转化为int,然后遍历
                path[i] = c;
                dfs(dfs,i + 1);// 递归下一层,只有进行完这层递归,for循环才能进入下一次循环
            }
        };
        dfs(dfs,0);// 递归入口,从头开始枚举 
        return ans;
    }
};


http://www.kler.cn/a/280001.html

相关文章:

  • 使用策略模式代替多个ifelse
  • 基于SSM+微信小程序的快递的管理系统(快递1)(源码+sql脚本+视频导入教程+文档)
  • CannotAcquireLockException产生原因及解决方案
  • apache的主要目录结构及常见的配置选项的详细说明(图例展示)
  • linux 系统性能调优技巧总结汇总
  • 视频转音频mp3软件有哪些?分享好用的转换工具
  • Mysql语句性能优化
  • YOLO与PyQt5结合-增加论文工作量-实现一个目标检测的UI界面
  • fork exec cow
  • 2 自研rk3566/rk3588+rgbd相机之设备树文件配置
  • 基于GPT回答:结合不同专业,论述GIS应用的关键技术问题
  • Selenium + Python 自动化测试23(综合实战)
  • shell程序设计入门(四)
  • ZooKeeper的节点上下线感知
  • 如何考取PostgreSQL认证证书?
  • 【网络安全】XML-RPC漏洞之盲SSRF
  • 【Electron】Electron学习笔记
  • Spring Boot如何压缩Json并写入redis?
  • 使用Blender进行3D建模—基础操作笔记
  • 小程序面试题一