最后更新于
最后更新于
给定一个数字,我们按照如下规则把它翻译为字符串:0 翻译成 “a” ,1 翻译成 “b”,……,11 翻译成 “l”,……,25 翻译成 “z”。一个数字可能有多个翻译。请编程实现一个函数,用来计算一个数字有多少种不同的翻译方法。
示例 1:
提示:
0 <= num < 231
动态规划的定义比较明确, dp[i]
表示的就是前i
位的子串可以有多少中翻译方法. 对于dp[i+1]
, 将s[i+1]
与s[:i+1]
是一种肯定可行的拼接思路, 另一种是将s[i:i+2]
这两个字符与s[:i]
拼接, 要求这两个字符组成的数字不能以0
开头, 且大小小于26(z
字符对应25), 这样就得到了状态转移公式.
最后直接返回dp[n]
即可, n
是数字的长度.