【算法与数据结构】17、LeetCode电话号码的字母组合

文章目录

所有的LeetCode题解索引,可以看这篇文章------【算法和数据结构】LeetCode题解

一、题目

二、解法

思路分析:本题需要解决的问题有三个:

  • 一、如何实现数字到字母的映射
  • 二、如何实现组合问题
  • 三、如何解决1 *等异常情况
      数字到字母的映射有两种,一种是寻找数字和字母之间的函数关系,但这种关系并不好找,2-6分别映射了三个字母,7 9 映射了四个字母,函数关系并不明显,因此我们直接建立一个数字到字母的映射map。
cpp 复制代码
const string letterMap[10] = {
    "", // 0
    "", // 1
    "abc", // 2
    "def", // 3
    "ghi", // 4
    "jkl", // 5
    "mno", // 6
    "pqrs", // 7
    "tuv", // 8
    "wxyz" // 9
};

第二个组合问题可以参考【算法与数据结构】77、LeetCode组合,稍做修改, 程序当中index来表示当前递归正在处理的数字的索引,终止条件为处理的索引=digits大小。同时利用ASCII码直接减去'0'得到对应的数字,并且做了异常值的处理,大于'9'小于'0'就是异常值。

程序如下:

cpp 复制代码
class Solution {
private:
    vector<string> result;     // 结果合集
    string path;
    void backtracking(const string& digits, int index) {    // index表示当前处理的数字索引
        if (index == digits.size()) {   // 终止条件
            result.push_back(path);
            return;
        }
        if (digits[index] > '9' || digits[index] < '0') {   // 异常处理
            result.clear();
            result.push_back("input_error");
            return;
        }
        else {
            int digit = digits[index] - '0';
            string letter = letterMap[digit];
            for (int i = 0; i < letter.size(); i++) { // 剪枝优化          
                path += letter[i];  // 处理节点
                backtracking(digits, index + 1);  // 递归
                path.pop_back();    // 回溯,撤销处理的节点
            }
        }
    }
public:
    const string letterMap[10] = {
    "", // 0
    "", // 1
    "abc", // 2
    "def", // 3
    "ghi", // 4
    "jkl", // 5
    "mno", // 6
    "pqrs", // 7
    "tuv", // 8
    "wxyz" // 9
    };
	vector<string> letterCombinations(string digits) {
        if(digits.size()) backtracking(digits, 0);           
        return result;
	}
};

复杂度分析:

  • 时间复杂度: O ( 3 m ∗ 4 n ) O(3^m*4^n) O(3m∗4n), m为映射有三个字母的数字个数,n为映射有四个字母的数字个数。
  • 空间复杂度: O ( 3 m ∗ 4 n ) O(3^m*4^n) O(3m∗4n)。

三、完整代码

cpp 复制代码
# include <iostream>
# include <vector>
# include <string>
using namespace std;

class Solution {
private:
    vector<string> result;     // 结果合集
    string path;
    void backtracking(const string& digits, int index) {    // index表示当前处理的数字索引
        if (index == digits.size()) {   // 终止条件
            result.push_back(path);
            return;
        }
        if (digits[index] > '9' || digits[index] < '0') {   // 异常处理
            result.clear();
            result.push_back("input_error");
            return;
        }
        else {
            int digit = digits[index] - '0';
            string letter = letterMap[digit];
            for (int i = 0; i < letter.size(); i++) { // 剪枝优化          
                path += letter[i];  // 处理节点
                backtracking(digits, index + 1);  // 递归
                path.pop_back();    // 回溯,撤销处理的节点
            }
        }
    }
public:
    const string letterMap[10] = {
    "", // 0
    "", // 1
    "abc", // 2
    "def", // 3
    "ghi", // 4
    "jkl", // 5
    "mno", // 6
    "pqrs", // 7
    "tuv", // 8
    "wxyz" // 9
    };
	vector<string> letterCombinations(string digits) {
        if(digits.size()) backtracking(digits, 0);           
        return result;
	}
};

int main() {
	string digits = "*";
    Solution s1;
    vector<string> result = s1.letterCombinations(digits);
    for (vector<string>::iterator jt = result.begin(); jt != result.end(); jt++) {
        cout << *jt << " ";
    }
    cout << endl;
	system("pause");
	return 0;
}

end

相关推荐
灵感__idea7 小时前
Hello 算法:“走一步看一步”的智慧
前端·javascript·算法
lwf0061649 小时前
导数学习日记
学习·算法·机器学习
头发够用的程序员9 小时前
从滑动窗口到矩阵运算:img2col算法基本原理
人工智能·算法·yolo·性能优化·矩阵·边缘计算·jetson
武帝为此10 小时前
【数据清洗缺失值处理】
python·算法·数学建模
Halo_tjn10 小时前
Java 基于字符串相关知识点
java·开发语言·算法
念越11 小时前
算法每日一题 Day08|双指针法解决三数之和
算法·力扣
黎阳之光11 小时前
黎阳之光透明管理:视频孪生重构智慧仓储新范式
人工智能·算法·安全·重构·数字孪生
CappuccinoRose12 小时前
回溯法 - 软考备战(四十三)
算法·排列组合·路径·n皇后·子集·解数独·岛屿
AC赳赳老秦12 小时前
OpenClaw进阶技巧:批量修改文件内容、替换关键词,解放双手
java·linux·人工智能·python·算法·测试用例·openclaw
Robot_Nav13 小时前
Shape-Aware MPPI(SA MPPI)算法:基于RC-ESDF的任意形状机器人实时轨迹优化
算法·机器人·sa-mppi