Leetcode Interleaving String problem solution YASH PAL, 31 July 2024 In this Leetcode Interleaving String problem solution we have Given strings s1, s2, and s3, find whether s3 is formed by an interleaving of s1 and s2. Problem solution in Python. class Solution: def isInterleave(self, s1: str, s2: str, s3: str) -> bool: if len(s1) + len(s2) != len(s3): return False found = False memo = set() def interleave(i,j): nonlocal memo, s1, s2, s3, found if (i,j) in memo: return if found: return if i == len(s1)-1 and j == len(s2)-1: found = True k = i+j+2 memo.add((i,j)) if i+1 < len(s1) and s1[i+1] == s3[k]: interleave(i+1, j) if j+1 < len(s2) and s2[j+1] == s3[k]: interleave(i,j+1) interleave(-1,-1) return found Problem solution in Java. class Solution { public boolean isInterleave(String s1, String s2, String s3) { if(s1.length()+s2.length() != s3.length()) return false; char[] a1 = s1.toCharArray(); char[] a2 = s2.toCharArray(); char[] a3 = s3.toCharArray(); int[][] dp = new int[a1.length+1][a2.length+1]; return helper(a1, a2,a3,0,0,0,dp); } boolean helper(char[] a1, char[] a2, char[] a3, int i1, int i2, int i3, int[][] dp) { if(i1==a1.length && i2==a2.length && i3==a3.length) return true; if(dp[i1][i2]!=0) return false; if(i1<a1.length && a1[i1]==a3[i3] ) { if(helper(a1, a2, a3, i1+1, i2, i3+1,dp)) return true; } if(i2<a2.length && a2[i2]==a3[i3]){ if(helper(a1, a2, a3, i1, i2+1, i3+1, dp)) return true; } dp[i1][i2]=1; return false; } } Problem solution in C++. class Solution { public: bool isInterleave(string s1, string s2, string s3) { int M, N; M = s1.length(); N = s2.length(); if (s3.length() != M + N) return false; bool T[M+1][N+1]; T[0][0] = true; for (int j = 1; j <= N; ++j) T[0][j] = T[0][j-1] && s2[j-1] == s3[j-1]; for (int i = 1; i <= M; ++i) T[i][0] = T[i-1][0] && s1[i-1] == s3[i-1]; for (int i = 1; i <= M; ++i) for (int j = 1; j <= N; ++j) T[i][j] = (T[i-1][j] && s1[i-1] == s3[i+j-1] ) || (T[i][j-1] && s2[j-1] == s3[i+j-1] ); return T[M][N]; } }; Problem solution in C. bool dp[1010]; bool isInterleave(char* s1, char* s2, char* s3) { int aLen = strlen(s1), bLen = strlen(s2), cLen = strlen(s3); if(aLen + bLen != cLen) return false; dp[0] = true; for(int j = 1; j <= bLen; j++) dp[j] = dp[j - 1] && (s2[j - 1] == s3[j - 1]); for(int i = 1; i <= aLen; i++){ char cur = s1[i - 1]; dp[0] = dp[0] && (s1[i - 1] == s3[i - 1]); for(int j = 1; j <= bLen; j++) dp[j] = (dp[j] && cur == s3[i + j - 1]) || (dp[j - 1] && s2[j - 1] == s3[i + j - 1]); } return dp[bLen]; } coding problems