• 【剑指offer系列】46. 把数字翻译成字符串


    这里是剑指offer系列的延续,作者将利用C++实现继续完成该系列的学习,剑指offer,喜欢的话可以点赞关注+收藏,加油更新中ing。


    题目46. 把数字翻译成字符串

    给定一个数字,我们按照如下规则把它翻译为字符串:

    0 翻译成 a,1 翻译成 b,……,11 翻译成 l,……,25 翻译成 z

    一个数字可能有多个翻译。

    例如 12258 有 5 种不同的翻译,它们分别是 bccfibwfibczimcfimzi

    请编程实现一个函数用来计算一个数字有多少种不同的翻译方法。

    数据范围
    输入数字位数 [1,101]。

    样例

    输入:"12258"
    
    输出:5
    
    • 1
    • 2
    • 3

    【题解】— 动态规划

    类比爬楼梯,dp[n] = dp[n-1]+dp[n-2] ,dp[n]代表走到最后一个字符,有多少种翻译方法。
    对于访问到当前的字符dp[n],能有多少种翻译?

    1. 当前字符翻译为1个字符这是一种方法,dp[n] = dp[n-1]
    2. 当前字符和前一个字符共同翻译为一种方法 dp[n]+=dp[n-2],此时的条件为前后两个字符可以翻译为同一个字符。以及 04,05,06,只能翻译为1种,其组合并不能作为一种翻译。

    复杂度分析:

    本题动态规划问题,时间复杂度为O(n)。
    
    • 1

    C++代码实现:

    class Solution {
    public:
        int getTranslationCount(string s) {
            if(s.empty()) return 0;
            int len = s.size();
            int dp[len+1];
            memset(dp,0,sizeof(dp));
            dp[0] = 1;
            dp[1] = 1;
            for (int i=2;i<=len;i++){
                dp[i] = dp[i-1];
                int  k = s[i-1] - '0';
                int k1 = s[i-2] - '0';
                if (k1 * 10 + k <= 25 && k1 != 0){
                    dp[i]  += dp[i-2];
                }
            }
            return dp[len];
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    在这里插入图片描述

    剑指offer系列将后续持续更新,有帮助的话,欢迎点赞👍、收藏⭐️+关注✌️哟~


  • 相关阅读:
    NZ系列工具NZ02:VBA读取PDF使用说明
    【C++】STL-priority_queue
    SpringBoot 异步编程浅谈
    Linux CentOS7 vim多窗口编辑
    【FPGA教程案例45】图像案例5——基于FPGA的图像均值滤波verilog实现,通过MATLAB进行辅助验证
    汽车烟雾测漏仪(EP120)
    Springboot 打印接口耗时
    自学(黑客技术)——网络安全
    想在期货市场存活 需要关注什么数据?
    实力进阶,教你使用thinkphp6开发一款商城系统
  • 原文地址:https://blog.csdn.net/weixin_46020266/article/details/126025006