[剑指Offer-46][中等][动态规划] 把数字翻译成字符串
题目描述
给定一个数字,我们按照如下规则把它翻译为字符串:0 翻译成 “a” ,1 翻译成 “b”,……,11 翻译成 “l”,……,25 翻译成 “z”。一个数字可能有多个翻译。请编程实现一个函数,用来计算一个数字有多少种不同的翻译方法。
示例 1:
输入: 12258
输出: 5
解释: 12258有5种不同的翻译,分别是"bccfi", "bwfi", "bczi", "mcfi"和"mzi"
提示:
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
是数字的长度.
class Solution:
def translateNum(self, num: int) -> int:
string = str(num)
f1, f2 = 1, 1
for i, char in enumerate(string[1:]):
count = f1
if string[i] != '0' and int(string[i: i + 2]) < 26:
count += f2
f1, f2 = count, f1
return f1
最后更新于
这有帮助吗?