★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(shanqingyongzhi)
➤博客園地址:山青詠芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址: http://www.javashuo.com/article/p-cnsedfii-me.html
➤若是連接不是山青詠芝的博客園地址,則多是爬取做者的文章。
➤原文已修改更新!強烈建議點擊原文地址閱讀!支持做者!支持原創!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★html
A message containing letters from A-Z
is being encoded to numbers using the following mapping way:git
'A' -> 1 'B' -> 2 ... 'Z' -> 26
Beyond that, now the encoded string can also contain the character '*', which can be treated as one of the numbers from 1 to 9.github
Given the encoded message containing digits and the character '*', return the total number of ways to decode it.微信
Also, since the answer may be very large, you should return the output mod 109 + 7.app
Example 1:編碼
Input: "*" Output: 9 Explanation: The encoded message can be decoded to the string: "A", "B", "C", "D", "E", "F", "G", "H", "I".
Example 2:加密
Input: "1*" Output: 9 + 9 = 18
Note:spa
一條包含字母 A-Z
的消息經過如下的方式進行了編碼:翻譯
'A' -> 1 'B' -> 2 ... 'Z' -> 26
除了上述的條件之外,如今加密字符串能夠包含字符 '*'了,字符'*'能夠被當作1到9當中的任意一個數字。code
給定一條包含數字和字符'*'的加密信息,請肯定解碼方法的總數。
同時,因爲結果值可能會至關的大,因此你應當對109 + 7取模。(翻譯者標註:此處取模主要是爲了防止溢出)
示例 1 :
輸入: "*" 輸出: 9 解釋: 加密的信息能夠被解密爲: "A", "B", "C", "D", "E", "F", "G", "H", "I".
示例 2 :
輸入: "1*" 輸出: 9 + 9 = 18(翻譯者標註:這裏1*能夠分解爲1,* 或者當作1*來處理,因此結果是9+9=18)
說明 :
1 class Solution { 2 func numDecodings(_ s: String) -> Int { 3 var e0:Int64 = 1 4 var e1:Int64 = 0 5 var e2:Int64 = 0 6 var f0:Int64 = 0 7 var M:Int64 = Int64(1e9 + 7) 8 for c in s.characters 9 { 10 if c == "*" 11 { 12 f0 = 9 * e0 + 9 * e1 + 6 * e2 13 e1 = e0 14 e2 = e0 15 } 16 else 17 { 18 f0 = e1 19 if c > "0" 20 { 21 f0 += e0 22 } 23 if c <= "6" 24 { 25 f0 += e2 26 } 27 e1 = c == "1" ? e0 : 0 28 e2 = c == "2" ? e0 : 0 29 } 30 e0 = f0 % M 31 } 32 return Int(e0) 33 } 34 }
340ms
1 /* Solution Space */ 2 3 class Solution 4 { 5 /* Algorithm */ 6 func numDecodings( _ string1: String ) -> Int 7 { 8 let allChar: UInt8 = "*".utf8.first! 9 let zeroChar: UInt8 = "0".utf8.first! 10 let values: [ Int ] = string1.utf8.map( 11 { 12 if $0 == allChar 13 { 14 return -1 15 } 16 else 17 { 18 return Int( $0 - zeroChar ) 19 } 20 } 21 ) 22 let mod: Int = 1000000007 23 24 /* Dynamic Results */ 25 var dynamicResults: [ Int ] = [ Int ].init( repeating: -1, count: ( values.count + 1 ) ) 26 dynamicResults[ values.count ] = 1 27 if values[ values.count - 1 ] == 0 28 { 29 dynamicResults[ values.count - 1 ] = 0 30 } 31 else if values[ values.count - 1 ] == -1 32 { 33 dynamicResults[ values.count - 1 ] = 9 34 } 35 else 36 { 37 dynamicResults[ values.count - 1 ] = 1 38 } 39 40 /* Counting Function - Recursive */ 41 func countDecodingsR( _ startIndex: Int ) -> Int 42 { 43 if dynamicResults[ startIndex ] != -1 44 { 45 return dynamicResults[ startIndex ] 46 } 47 if values[ startIndex ] == 0 48 { 49 dynamicResults[ startIndex ] = 0 50 return dynamicResults[ startIndex ] 51 } 52 dynamicResults[ startIndex ] = 0 53 if values[ startIndex ] == -1 54 { 55 dynamicResults[ startIndex ] = 56 ( 57 dynamicResults[ startIndex ] 58 + ( 9 * countDecodingsR( startIndex + 1 ) ) % mod 59 ) % mod 60 if values[ startIndex + 1 ] == -1 61 { 62 dynamicResults[ startIndex ] = 63 ( 64 dynamicResults[ startIndex ] 65 + ( 15 * countDecodingsR( startIndex + 2 ) ) % mod 66 ) % mod 67 } 68 else 69 { 70 if 10 + values[ startIndex + 1 ] <= 26 71 { 72 dynamicResults[ startIndex ] = 73 ( 74 dynamicResults[ startIndex ] 75 + countDecodingsR( startIndex + 2 ) 76 ) % mod 77 } 78 if 20 + values[ startIndex + 1 ] <= 26 79 { 80 81 dynamicResults[ startIndex ] = 82 ( 83 dynamicResults[ startIndex ] 84 + countDecodingsR( startIndex + 2 ) 85 ) % mod 86 } 87 } 88 } 89 else 90 { 91 dynamicResults[ startIndex ] = 92 ( 93 dynamicResults[ startIndex ] 94 + countDecodingsR( startIndex + 1 ) 95 ) % mod 96 if values[ startIndex + 1 ] == -1 97 { 98 var value: Int = values[ startIndex ] * 10 99 for digit in ( 1 ... 9 ) 100 { 101 if value + digit <= 26 102 { 103 dynamicResults[ startIndex ] = 104 ( 105 dynamicResults[ startIndex ] 106 + countDecodingsR( startIndex + 2 ) 107 ) % mod 108 } 109 else 110 { 111 break 112 } 113 } 114 } 115 else 116 { 117 let value: Int = values[ startIndex ] * 10 + values[ startIndex + 1 ] 118 if value <= 26 119 { 120 dynamicResults[ startIndex ] = 121 ( 122 dynamicResults[ startIndex ] 123 + countDecodingsR( startIndex + 2 ) 124 ) % mod 125 } 126 } 127 } 128 return dynamicResults[ startIndex ] 129 } 130 131 /* Counting Function - Iterative */ 132 func countDecodingsI() 133 { 134 var currentIndex: Int = ( values.count - 2 ) 135 while currentIndex >= 0 136 { 137 if values[ currentIndex ] == 0 138 { 139 dynamicResults[ currentIndex ] = 0 140 currentIndex -= 1 141 continue 142 } 143 dynamicResults[ currentIndex ] = 0 144 if values[ currentIndex ] == -1 145 { 146 dynamicResults[ currentIndex ] = 147 ( 148 dynamicResults[ currentIndex ] 149 + ( 9 * dynamicResults[ currentIndex + 1 ] ) % mod 150 ) % mod 151 if values[ currentIndex + 1 ] == -1 152 { 153 dynamicResults[ currentIndex ] = 154 ( 155 dynamicResults[ currentIndex ] 156 + ( 15 * dynamicResults[ currentIndex + 2 ] ) % mod 157 ) % mod 158 } 159 else 160 { 161 if 10 + values[ currentIndex + 1 ] <= 26 162 { 163 dynamicResults[ currentIndex ] = 164 ( 165 dynamicResults[ currentIndex ] 166 + dynamicResults[ currentIndex + 2 ] 167 ) % mod 168 } 169 170 if 20 + values[ currentIndex + 1 ] <= 26 171 { 172 dynamicResults[ currentIndex ] = 173 ( 174 dynamicResults[ currentIndex ] 175 + dynamicResults[ currentIndex + 2 ] 176 ) % mod 177 } 178 } 179 } 180 else 181 { 182 dynamicResults[ currentIndex ] = 183 ( 184 dynamicResults[ currentIndex ] 185 + dynamicResults[ currentIndex + 1 ] 186 ) % mod 187 if values[ currentIndex + 1 ] == -1 188 { 189 var value: Int = values[ currentIndex ] * 10 190 for digit in ( 1 ... 9 ) 191 { 192 if value + digit <= 26 193 { 194 dynamicResults[ currentIndex ] = 195 ( 196 dynamicResults[ currentIndex ] 197 + dynamicResults[ currentIndex + 2 ] 198 ) % mod 199 } 200 else 201 { 202 break 203 } 204 } 205 } 206 else 207 { 208 let value: Int = values[ currentIndex ] * 10 + values[ currentIndex + 1 ] 209 if value <= 26 210 { 211 dynamicResults[ currentIndex ] = 212 ( 213 dynamicResults[ currentIndex ] 214 + dynamicResults[ currentIndex + 2 ] 215 ) % mod 216 } 217 } 218 } 219 currentIndex -= 1 220 } 221 } 222 countDecodingsI() 223 return dynamicResults[ 0 ] 224 } 225 }
780ms
1 class Solution { 2 func numDecodings(_ s: String) -> Int { 3 guard s.count > 0 else { return 0 } 4 let s = Array(s).map{ "\($0)" } 5 var dp = Array(repeating: 0, count: s.count) 6 dp[0] = s[0] == "*" ? 9 : s[0] == "0" ? 0 : 1 7 for i in 1..<s.count { 8 var r = (i > 1) ? dp[i-2] : 1 9 if s[i] == "*" { 10 dp[i] = dp[i] &+ dp[i-1] * 9 11 if s[i-1] == "1" { dp[i] = dp[i] &+ r * 9 } 12 if s[i-1] == "2" { dp[i] = dp[i] &+ r * 6 } 13 if s[i-1] == "*" { dp[i] = dp[i] &+ r * 15 } 14 } else if s[i] == "0" { 15 r = (i > 1) ? dp[i-2] : 1 16 if s[i-1] == "1" || s[i-1] == "2" { dp[i] += r * 1 } 17 if s[i-1] == "*" { dp[i] += r * 2 } 18 } else { 19 dp[i] = dp[i] &+ dp[i-1] 20 if s[i-1] == "1" || (s[i-1] == "2" && Int(s[i])! < 7) { dp[i] = dp[i] &+ ((i > 1) ? dp[i-2] : 1) } 21 if s[i-1] == "*" && Int(s[i])! < 7 { dp[i] = dp[i] &+ r * 2 } 22 if s[i-1] == "*" && Int(s[i])! >= 7 { dp[i] = dp[i] &+ r * 1 } 23 } 24 dp[i] %= 1000000007 25 } 26 return dp.last ?? 0 27 } 28 }