栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

蓝肽子序列 【决赛】(python)

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

蓝肽子序列 【决赛】(python)

分析

从题目中可以看出本题要求的是最长蓝肽子公共子序列,我们都知道最长公共子序列是经典的动态规划算法,本题最长蓝肽子公共子序列经过一定的处理后可以转化为最长公共子序列问题。

代码
s1 = input()
s2 = input()
def createDict(s):
    n = len(s)
    d = []
    start = 0
    for i in range(n):
        if i>0 and s[i] >= 'A' and s[i] <= 'Z' :
            d.append(s[start:i])
            start = i
    d.append(s[start:n])
    return d
d1 = createDict(s1)
d2 = createDict(s2)
# 最长公共子序列
n, m = len(d1), len(d2)
dp = [[0]*(m+1) for _ in range(n+1)]
for i in range(1,n+1):
    for j in range(1,m+1):
        if d1[i-1] == d2[j-1]:
            dp[i][j] = dp[i-1][j-1] + 1
        else:
            dp[i][j] = max(dp[i-1][j], dp[i][j-1])
print(dp[n][m])

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/876384.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号