java刷题--91解码方法
Posted Anrys
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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解码方法的主要内容,如果未能解决你的问题,请参考以下文章