class Solution:
def longestCommonSubsequence(self, word1: str, word2: str) -> int:
@lru_cache(None)
def helper(i, j):
if i == len(word1) or j == len(word2):
return 0
if word1[i] == word2[j]:
return 1 + helper(i+1, j+1)
else:
return max(helper(i+1, j), helper(i, j+1))
return helper(0, 0)
def minDistance(self, word1: str, word2: str) -> int:
lcs = self.longestCommonSubsequence(word1, word2)
return len(word1) + len(word2) - 2 * lcs