题目: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:还是得日更呀,总结一下总是好的。