一条包含字母 A-Z 的消息通过以下方式进行了编码:
'A' -> 1
'B' -> 2
...
'Z' -> 26
给定一个只包含数字的非空字符串,请计算解码方法的总数。
示例 1:
输入: "12"
输出: 2
解释: 它可以解码为 "AB"(1 2)或者 "L"(12)。
示例 2:
输入: "226"
输出: 3
解释: 它可以解码为 "BZ" (2 26), "VF" (22 6), 或者 "BBF" (2 2 6) 。
参考leetcode : https://leetcode-cn.com/problems/decode-ways/comments/
https://leetcode-cn.com/bao-bao-ke-guai-liao/
1 class Solution91 {
2
3 public int numDecodings(String s) {
4 if (s == null || s.length() == 0 || s.charAt(0) == '0') {
5 return 0;
6 }
7 int[] dp = new int[s.length()];
8 dp[0] = 1;
9 for (int i = 1; i < s.length(); i++) {
10 char currChar = s.charAt(i);
11 char preChar = s.charAt(i - 1);
12 int i1 = dp[i - 2 >= 0 ? i - 2 : 0]; //i-2可能<=0.如果越界,说明i=1,按照规律赋予0即可
13
14 if (currChar == '0' && preChar <= '2' && preChar != '0') { //如果currChar为'0'并且他能和前一个char组合
15 dp[i] = i1;
16 } else if (currChar != '0') { //如果currChar不为'0',他一定能编码
17 dp[i] = ((preChar == '1') || (preChar == '2' && currChar <= '6') ? i1 : 0) + dp[i - 1];
18 } else { //否则就属于currChar为'0'但不能和前一个char组合
19 return 0;
20 }
21 }
22 return dp[s.length() - 1];
23 }
24 }