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

把数字翻译成字符串

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

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 解码
     * @param nums string字符串 数字串
     * @return int整型
     */
    int solve(string nums) {
        // write code here
        int n=nums.length();
        vector<int> dp(n);
        if(nums[0]-'0'!=0) dp[0]=1;
        int tmp=(nums[0]-'0')*10+(nums[1]-'0');
        if(nums[1]-'0'!=0) dp[1]=dp[0];
        if(tmp>=10&&tmp<=26) dp[1]+=1;

        for(int i=2;i<n;++i){
            if(nums[i]-'0'!=0) dp[i]+=dp[i-1];
            int tmp = (nums[i-1]-'0')*10+(nums[i]-'0');
            if(tmp>=10&&tmp<=26) dp[i]+=dp[i-2];
        }
        return dp[n-1];
    }
};

全部评论

相关推荐

07-07 12:47
门头沟学院 Java
码农索隆:竟然还真有卡体检报告的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务