java: add “91. Decode Ways”
Signed-off-by: Matej Focko <me@mfocko.xyz>
This commit is contained in:
parent
f0e0adde9f
commit
d3bc57de18
1 changed files with 51 additions and 0 deletions
51
java/decode-ways.java
Normal file
51
java/decode-ways.java
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
class Solution {
|
||||||
|
private static final int EMPTY = -1;
|
||||||
|
|
||||||
|
private static int charToDigit(String s, int i) {
|
||||||
|
return s.charAt(i) - '0';
|
||||||
|
}
|
||||||
|
|
||||||
|
private int numDecodings(String s, int[] dp, int i) {
|
||||||
|
// out of bounds
|
||||||
|
if (i < 0 || i > s.length()) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// final digit
|
||||||
|
if (i == s.length()) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// starting with 0, not allowed
|
||||||
|
if (s.charAt(i) == '0') {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// solution has been already precomputed
|
||||||
|
if (dp[i] != EMPTY) {
|
||||||
|
return dp[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
// taking just one digit
|
||||||
|
int result = numDecodings(s, dp, i + 1);
|
||||||
|
|
||||||
|
// taking two digits
|
||||||
|
if (i + 1 < s.length() && charToDigit(s, i) * 10 + charToDigit(s, i + 1) <= 26) {
|
||||||
|
result += numDecodings(s, dp, i + 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
// save and return
|
||||||
|
dp[i] = result;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int numDecodings(String s) {
|
||||||
|
int[] dp = new int[s.length()];
|
||||||
|
for (int i = 0; i < dp.length; ++i) {
|
||||||
|
dp[i] = EMPTY;
|
||||||
|
}
|
||||||
|
|
||||||
|
return numDecodings(s, dp, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue