g0001_0100.s0097_interleaving_string.Solution Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of leetcode-in-java Show documentation
Show all versions of leetcode-in-java Show documentation
Java-based LeetCode algorithm problem solutions, regularly updated
package g0001_0100.s0097_interleaving_string;
// #Medium #String #Dynamic_Programming #2022_02_21_Time_1_ms_(96.15%)_Space_42.4_MB_(24.98%)
public class Solution {
public boolean isInterleave(String s1, String s2, String s3) {
if (s3.length() != (s1.length() + s2.length())) {
return false;
}
Boolean[][] cache = new Boolean[s1.length() + 1][s2.length() + 1];
return isInterleave(s1, s2, s3, 0, 0, 0, cache);
}
public boolean isInterleave(
String s1, String s2, String s3, int i1, int i2, int i3, Boolean[][] cache) {
if (cache[i1][i2] != null) {
return cache[i1][i2];
}
if (i1 == s1.length() && i2 == s2.length() && i3 == s3.length()) {
return true;
}
boolean result = false;
if (i1 < s1.length() && s1.charAt(i1) == s3.charAt(i3)) {
result = isInterleave(s1, s2, s3, i1 + 1, i2, i3 + 1, cache);
}
if (i2 < s2.length() && s2.charAt(i2) == s3.charAt(i3)) {
result = result || isInterleave(s1, s2, s3, i1, i2 + 1, i3 + 1, cache);
}
cache[i1][i2] = result;
return result;
}
}