在 Python 中查找两个给定字符串的公共特殊子字符串的大小的程序
假设我们有两个字符串s1和s2。我们必须找到最长字符串s3的大小,它是s1和s2的特殊子串。
如果可以通过从y中删除0个或多个字符来生成x,我们可以说字符串x是另一个字符串y的特殊子字符串。
因此,如果输入类似于s1='pineapple's2='people',那么输出将为5,因为特殊子串是'peple',大小为5。
示例
让我们看看以下实现以获得更好的理解-
from collections import defaultdict
def solve(s1, s2):
prev = defaultdict(int)
for i in range(len(s1)):
cur = defaultdict(int)
for j in range(len(s2)):
cur[j] = prev[j - 1] + 1 if s1[i] == s2[j] else max(cur[j - 1], prev[j])
prev = cur
return prev[len(s2)-1]
s1 = 'pineapple'
s2 = 'people'
print(solve(s1, s2))输入
'pineapple', 'people'输出结果
5
热门推荐
10 嫂子生日的祝福语简短
11 新娘上头祝福语大全简短
12 写给男生简短的祝福语
13 端午老师祝福语简短优美
14 元旦联谊祝福语简短精辟
15 冬至婆婆的祝福语简短
16 生日祝福语大全女孩简短
17 龙年简短祝福语有哪些
18 新婚过年祝福语大全简短