LeetCode 第91题 解码方法

一条包含字母 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 }

猜你喜欢

转载自www.cnblogs.com/rainbow-/p/10544268.html