java刷题--91解码方法

Posted Anrys

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java刷题--91解码方法相关的知识,希望对你有一定的参考价值。

java刷题--91解码方法

题目

代码

class Solution {
    public int numDecodings(String s) {
        int n = s.length();
        int[] f = new int[n+1];
        f[0] = 1;
        for (int i = 1; i <= n; i++) {
            //计算单干情况的累加和
            if (s.charAt(i - 1) != '0') f[i] += f[i - 1]; 
            //计算存在双位数情况的额外累计
            if (i > 1 && s.charAt(i - 2) != '0' && ((s.charAt(i - 2) - '0') * 10 + (s.charAt(i - 1) - '0') <= 26)) {
                f[i] += f[i - 2];
            }
        }return f[n];
    }
}

结果

以上是关于java刷题--91解码方法的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode 91. 解码方法c++/java详细题解

LeetCode刷题模版:91 - 100

LeetCode刷题模版:91 - 100

leetcode 91. 解码方法 JAVA

(Java) LeetCode 91. Decode Ways —— 解码方法

LeetCode第[91]题(Java):Decode Ways(解码方法数)