[剑指Offer-46][中等][动态规划] 把数字翻译成字符串

题目描述

剑指 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

最后更新于

这有帮助吗?