#coding:utf-8 # # 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 # # 解码 # @param nums string字符串 数字串 # @return int整型 # class Solution: def solve(self , nums): #排除0 if nums == "0": return 0 #排除只有一种可能的10 和 20 if nums == "10" or nums == "20": return 1 #当0的前面不是1或2时,无法译码,0种 for i in range(1, len(nums)): if nums[i] == '0': if nums[i - 1] != '1' and nums[i - 1] != '2': return 0 #辅助数组初始化为1 dp = [1 for i in range(len(nums) + 1)] for i in range(2, len(nums) + 1): #在11-19,21-26之间的情况 if (nums[i - 2] == '1' and nums[i - 1] != '0') or (nums[i - 2] == '2' and nums[i - 1] > '0' and nums[i - 1] < '7'): dp[i] = dp[i - 1] + dp[i - 2] else: dp[i] = dp[i - 1] return dp[len(nums)]