前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >打卡群刷题总结0801——解码方法

打卡群刷题总结0801——解码方法

作者头像
木又AI帮
发布2020-08-04 17:07:09
3900
发布2020-08-04 17:07:09
举报
文章被收录于专栏:木又AI帮

题目:91. 解码方法

链接:https://leetcode-cn.com/problems/decode-ways

一条包含字母 A-Z 的消息通过以下方式进行了编码: 'A' -> 1 'B' -> 2 ... 'Z' -> 26 给定一个只包含数字的非空字符串,请计算解码方法的总数。 示例 1: 输入: "12" 输出: 2 解释: 它可以解码为 "AB"(1 2)或者 "L"(12)。 示例 2: 输入: "226" 输出: 3 解释: 它可以解码为 "BZ" (2 26), "VF" (22 6), 或者 "BBF" (2 2 6) 。

解题:

1、DP。

代码:

代码语言:javascript
复制
class Solution(object):
    def numDecodings(self, s):
        """
        :type s: str
        :rtype: int
        """
        if len(s) == 0:
            return 0
        if s[0] == '0':
            return 0

        # 00, 30, 40...90: return 0
        # 10, 20: dp[i] = dp[i - 2]
        # 27-99(exclude 30, 40, ...)): dp[i] = dp[i - 1]
        # 1-26(exclude 10, 20): dp[i] = dp[i - 1] + dp[i - 2]
        dp = [0] * (len(s) + 1)
        dp[0] = 1
        dp[1] = 1
        for i in range(1, len(s)):
            if s[i] == '0':
                if s[i - 1] == '0' or s[i - 1] >= '3':
                    return 0
                else:
                    dp[i + 1] = dp[i - 1]
            elif s[i - 1] == '0' or s[i - 1] >= '3':
                dp[i + 1] = dp[i]
            elif s[i - 1] == '2' and s[i] >= '7':
                dp[i + 1] = dp[i]
            else:
                dp[i + 1] = dp[i] +dp[i - 1]
        print(dp)
        return dp[-1]

PS:刷了打卡群的题,再刷另一道题,并且总结,确实耗费很多时间。如果时间不够,以后的更新会总结打卡群的题。

PPS:还是得日更呀,总结一下总是好的。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-08-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 木又AI帮 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 链接:https://leetcode-cn.com/problems/decode-ways
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档