ms-hot29 解码方法

leetcode原题链接: 解码方法

ms-hot目录: ​​​​​​ ms-hot目录

上一篇ms-hot28 合并两个有序数组

下一篇:二叉树的中序遍历

题目描述

一条包含字母 A-Z 的消息通过以下映射进行了 编码

"1" -> 'A'
"2" -> 'B'
...
"25" -> 'Y'
"26" -> 'Z'

然而,在 解码 已编码的消息时,你意识到有许多不同的方式来解码,因为有些编码被包含在其它编码当中("2""5""25")。

例如,"11106" 可以映射为:

  • "AAJF" ,将消息分组为 (1, 1, 10, 6)
  • "KJF" ,将消息分组为 (11, 10, 6)
  • 消息不能分组为 (1, 11, 06) ,因为 "06" 不是一个合法编码(只有 "6" 是合法的)。

注意,可能存在无法解码的字符串。

给你一个只含数字的 非空 字符串 s ,请计算并返回 解码 方法的 总数 。如果没有合法的方式解码整个字符串,返回 0

题目数据保证答案肯定是一个 32 位 的整数。

示例 1:

复制代码
输入:s = "12"
输出:2
解释:它可以解码为 "AB"(1 2)或者 "L"(12)。

示例 2:

复制代码
输入:s = "226"
输出:3
解释:它可以解码为 "BZ" (2 26), "VF" (22 6), 或者 "BBF" (2 2 6) 。

示例 3:

复制代码
输入:s = "06"
输出:0
解释:"06" 无法映射到 "F" ,因为存在前导零("6" 和 "06" 并不等价)。

给你一个只含数字的 非空 字符串 s ,请计算并返回 解码 方法的 总数 。如果没有合法的方式解码整个字符串,返回 0

题目数据保证答案肯定是一个 32 位 的整数。

示例 1:

复制代码
输入:s = "12"
输出:2
解释:它可以解码为 "AB"(1 2)或者 "L"(12)。

示例 2:

复制代码
输入:s = "226"
输出:3
解释:它可以解码为 "BZ" (2 26), "VF" (22 6), 或者 "BBF" (2 2 6) 。

示例 3:

复制代码
输入:s = "06"
输出:0
解释:"06" 无法映射到 "F" ,因为存在前导零("6" 和 "06" 并不等价)。

提示:

  • 1 <= s.length <= 100
  • s 只包含数字,并且可能包含前导零。

解题方法:动态规划DP。

  1. 问题定义: dpi表示以第i个字符结尾的解码方法数,则申请n+1大小的dp数组。

  2. 初始化:

dp0=1

如果s1 >= '1' and s1<='9' ==> dp1=1; 否则dp1=0

  1. 状态转移方程:考虑点是si是单独解码,还是si-1, si两个字符一起解码。

1)如果si单独解码:则dpi+1 = dpi+1 + dpi --注意最开始的时候dpi+1默认值为0;

2)如果si和si-1一起解码,则需要判断si-1和si组成的数组num是否满足 1 <= num <= 26这个条件,如果满足这个条件,则dpi+1 = dpi+1 + dpi-1

  1. 返回解:最后求到的dpn即为以最后一个字符结尾的解码数,即为问题的解。
C++代码
cpp 复制代码
#include <iostream>
#include <string>
#include <vector>
class Solution {
public:
    int numDecodings(string s) {
        int n = s.size();
        if (n == 0) {
            return 0;
        }
        vector<int> dp(n + 1, 0); //dp[i]表示以第i个字符结尾的字符串对应的解码方法数
        dp[0] = 1; //初始化:空字符串解码数为1(即解码出一个空字符串)
        dp[1] = (s[0] >= '1' && s[0] <= '9') ? 1 : 0;
        for (int i = 1; i < n; i++) {
            int cur = s[i] - '0';
            int pre = s[i - 1] - '0';
            if (cur >= 1) { //考虑s[i]单独解码
                dp[i + 1] += dp[i];
            }
            if (pre == 1 ||(pre == 2 && cur <= 6) ) { //考虑s[i]和s[i-1]一起解码
                dp[i + 1] += dp[i - 1];
            }
        }
        return dp[n];
    }
};
相关推荐
8Qi830 分钟前
LeetCode 75:颜色分类(荷兰国旗问题)—— Java 题解 ✅
java·算法·leetcode·指针·排序
888CC++2 小时前
如何在 C 语言中进行程序调试?
前端·javascript·算法
(●—●)橘子……3 小时前
力扣第503场周赛练习理解
python·学习·算法·leetcode·职场和发展·周赛
明志数科5 小时前
4D时序标注技术详解:让机器人理解连续动作的数据基础
java·算法·机器人
feng_you_ying_li5 小时前
C++复习二,继承与多态
c++
小小de风呀5 小时前
de风——【从零开始学C++】(十一):list的基本使用和模拟实现
开发语言·c++·list
KaMeidebaby5 小时前
卡梅德生物技术快报|原核表达系统工艺优化:包涵体重折叠 + 分子筛纯化实现功能 RBD 高效制备,附全参数配置
前端·人工智能·算法·数据挖掘·数据分析
陌路206 小时前
C++高级进阶--夯实进阶基础(1)
开发语言·c++
无限码力6 小时前
携程0510笔试真题【单数组交换】
算法·携程笔试·携程笔试真题·携程0510笔试真题