题解 | #把数字翻译成字符串#

把数字翻译成字符串

http://www.nowcoder.com/practice/046a55e6cd274cffb88fc32dba695668

// if s[i]=0 
//     dp[i] = dp[i-2] 
// else 
//     if  s[i]+s[i-1]*10 <= 26
//         if  s[i-1]!=0
//             dp[i] = dp[i-1] + dp[i-2] 
//         if s[i-1]=0 
//             dp[i] = dp[i-1]  

 function solve( nums ) {
    // write code here
    const len = nums.length
    if (len == 0 || (len == 1 && nums[0] == '0')){
        return 0
    }
    let dp = [1]
    for (let i = 1; i < len; i++) {
        if(nums[i] == '0'){
            // 连续两个0,或者0前面的数大于2则无法解码0的部分
            if (nums[i-1] == '0' || parseInt(nums[i-1])>2 ){
                return 0
            }
            if (i > 1){
               dp.push(dp.slice(-2)[0]) 
            }
            // 字符串第二位即为0
            else
                dp.push(1)
        }
        else{
            if (parseInt(nums[i])+parseInt(nums[i-1])*10>26){
                dp.push(dp.slice(-1)[0])
            }
            else{
                if (nums[i-1] != '0'){
                    dp.push(dp.slice(-1)[0] + dp.slice(-2)[0])
                }
                else{
                    dp.push(dp.slice(-1)[0])
                }
            }
        }
    }
    return dp.slice(-1)[0]
}
全部评论

相关推荐

沉淀一会:1.同学你面试评价不错,概率很大,请耐心等待; 2.你的排名比较靠前,不要担心,耐心等待; 3.问题不大,正在审批,不要着急签其他公司,等等我们! 4.预计9月中下旬,安心过节; 5.下周会有结果,请耐心等待下; 6.可能国庆节前后,一有结果我马上通知你; 7.预计10月中旬,再坚持一下; 8.正在走流程,就这两天了; 9.同学,结果我也不知道,你如果查到了也告诉我一声; 10.同学你出线不明朗,建议签其他公司保底! 11.同学你找了哪些公司,我也在找工作。
点赞 评论 收藏
分享
有工作后先养猫:太好了,是超时空战警,我们有救了😋
点赞 评论 收藏
分享
1 收藏 评论
分享
牛客网
牛客企业服务