力扣每日一题91:解码方法

题目描述:

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

复制代码
'A' -> "1"
'B' -> "2"
...
'Z' -> "26"

解码 已编码的消息,所有数字必须基于上述映射的方法,反向映射回字母(可能有多种方法)。例如,"11106" 可以映射为:

  • "AAJF" ,将消息分组为 (1 1 10 6)
  • "KJF" ,将消息分组为 (11 10 6)

注意,消息不能分组为 (1 11 06) ,因为 "06" 不能映射为 "F" ,这是由于 "6""06" 在映射中并不等价。

给你一个只含数字的 非空 字符串 s ,请计算并返回 解码 方法的 总数

题目数据保证答案肯定是一个 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 只包含数字,并且可能包含前导零。

通过次数

285.3K

提交次数

855.5K

通过率

33.3%

思路和题解(动态规划):

设定一个数组dp[n+1],用dp[i]表示 从第1个位置开始到第i个数字结束 的字符串的解码方法的总数,dp[0]=1;当第i个数字等于零时dp[i]=0;当第i个数字不等于零时,表示可以先解码到第i-1个数,再解码解到第i个数,此时dp[i]+=dp[i-1];此时再判断i的前两个数字(要保证i>=2)组成的数是不是在[1,26]内,如果是,表示可以先解码到第i-2个数,再解码解到第i个数,则dp[i]+=dp[i-2];最后dp[n]即为答案。

代码:

cpp 复制代码
class Solution {
public:
    int numDecodings(string s) {
        int n=s.length();
        vector<int> dp(n+1,0);
        dp[0]=1;
        for(int i=1;i<=n;i++)
        {
            //从前面第一个跳过来
            if(s[i-1]!='0')
            {
                dp[i]+=dp[i-1];
            }
            //从前面第二个跳过来
            if( i>1&&s[i-2]!='0'&&((s[i-2]-'0')*10+s[i-1]-'0')<=26 )
            {
                dp[i]+=dp[i-2];
            }
        }
        return dp[n];
    }
};
相关推荐
IT 行者6 分钟前
Spring Security 7.0 新特性详解
java·后端·spring
dragoooon347 分钟前
[hot100 NO.31~36]
数据结构·算法·排序算法
白兰地空瓶7 分钟前
JavaScript 列表转树(List to Tree)详解:前端面试中如何从递归 O(n²) 优化到一次遍历 O(n)
javascript·算法·面试
艾醒9 分钟前
大模型原理剖析——从技术特性、底层架构到落地逻辑的全维度解析
算法
华仔啊12 分钟前
Java 的金额计算用 long 还是 BigDecimal?资深程序员这样选
java·后端
Coder_Boy_16 分钟前
业务导向型技术日志记录(2)
java·人工智能·驱动开发·微服务
Liangwei Lin21 分钟前
洛谷 B3637 最长上升子序列
算法
凤凰战士芭比Q23 分钟前
Jenkins(环境变量、构建参数、流水线触发、通知报告)
java·servlet·jenkins
运维@小兵32 分钟前
Spring AI系列——开发MCP Server和MCP Client(SSE方式)
java·人工智能·spring
有一个好名字32 分钟前
设计模式-代理模式
java·设计模式·代理模式