【剑指Offer】46. 把数字翻译成字符串

题目链接:把数字翻译成字符串

题目描述:

给定一个数字,我们按照如下规则把它翻译为字符串:0 翻译成 “a” ,1 翻译成 “b”,……,11 翻译成 “l”,……,25 翻译成 “z”。一个数字可能有多个翻译。请编程实现一个函数,用来计算一个数字有多少种不同的翻译方法。

题目分析:

1)每一位上的数字都可以单独翻译成一个字符,且该位和其前一位的构成的数字小于26时,也可以一起翻译成一个字符。

2)动态规划,用dp[n]表示一个n位的数字能够翻译成的字符串的个数,那么将包含n位的数字转换成一个字符串str,

        状态转移方程:

        当str[i-1]+str[i]>=26时,dp[i]=dp[i-1],i位数字翻译成的字符串只是在i-1位数字翻译成的字符串后面添加一个字符,字符串的个数不变。

        当str[i-1]+str[i]<26时,dp[i]=dp[i-1]+dp[i-2],i位数字翻译成的字符串除了在i-1位数字翻译成的字符串后面添加一个字符,还可以在i-2位数字翻译成的字符串后面添加一个字符,字符串个数为两种情况的字符串总和。

        边界条件就是:

        dp[1]=1,dp[2]=1或2,取决于前两位构成的数字和26的关系。

js代码如下:

var translateNum = function(num) {
    if(num<10)
        return 1;
    let str=num.toString();
    const length=str.length;
    let dp=new Array(length).fill(0);
    dp[0]=1;
    for(let i=1;i<length;i++){
        if(str[i-1]!=='0' && parseInt(str[i-1]+str[i])<26){
            dp[i]=i==1?dp[i-1]+1:dp[i-2]+dp[i-1];
        }
        else
            dp[i]=dp[i-1];
    }
    return dp[length-1];
};

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值