function isInterleave(s1: string, s2: string, s3: string): boolean {
const m = s1.length;
const n = s2.length;
if (m + n !== s3.length) {
return false;
}
const f: boolean[][] = new Array(m + 1).fill(0).map(() => new Array(n + 1).fill(false));
f[0][0] = true;
for (let i = 0; i <= m; ++i) {
for (let j = 0; j <= n; ++j) {
const k = i + j - 1;
if (i > 0 && s1[i - 1] === s3[k]) {
f[i][j] = f[i - 1][j];
}
if (j > 0 && s2[j - 1] === s3[k]) {
f[i][j] = f[i][j] || f[i][j - 1];
}
}
}
return f[m][n];
}