给出两个字符串 str1 和 str2,返回同时以 str1 和 str2 作为子序列的最短字符串。如果答案不止一个,则可以返回满足条件的任意一个答案。
(如果从字符串 T 中删除一些字符(也可能不删除,并且选出的这些字符可以位于 T 中的 任意位置),可以得到字符串 S,那么 S 就是 T 的子序列)
from typing import *
from collections import defaultdict
class Solution:
def shortestCommonSupersequence(self, str1: str, str2: str) -> str:
dp = defaultdict(lambda: '')
m, n = len(str1), len(str2)
for i in range(1, m + 1):
for j in range(1, n + 1):
if str1[i - 1] == str2[j - 1]:
dp[i, j] = dp[i - 1, j - 1] + str1[i - 1]
else:
if len(dp[i - 1, j]) > len(dp[i, j - 1]):
dp[i, j] = dp[i - 1, j]
else:
dp[i, j] = dp[i, j - 1]
s = dp[m, n]
i, j = 0, 0
ans = []
for c in s:
while i < m and str1[i] != c:
ans.append(str1[i])
i += 1
while j < n and str2[j] != c:
ans.append(str2[j])
j += 1
ans.append(c)
i += 1
j += 1
return ''.join(ans) + str1[i:] + str2[j:]