题解 | #最大子序列#

最大子序列

https://www.nowcoder.com/practice/17ba5b5df1fc49ca8d6cf8ea407b1972

s = input().strip()
# 动态规划:dp[i]以i结尾的最大字典序
'''
t e/te s/ts/tes t/tt/tes/test
'''
dp = ["" for _ in range(len(s))]
dp[0] = s[0]
for i in range(len(s)):
    for j in range(0, i):
        dp[i] = max(dp[j]+s[i], dp[i], s[i])
print(dp[len(s)-1])

动态规划可以解决大多数的子序问题,

输入test,每一轮比较如注释:

t e/te s/ts/tes t/tt/tes/test

dp的更新考虑每一个前序dp加上当前字符的最大值;或者重启起始字符串,从s[i]开始

时间复杂度O(n2)

(第一个题解,看答得人不多就写了)

全部评论

相关推荐

10-28 10:48
已编辑
门头沟学院 Java
孩子我想要offer:发笔试后还没笔试把我挂了,然后邮箱一直让我测评没测,后面不知道干嘛又给我捞起来下轮笔试,做完测评笔试又挂了😅
点赞 评论 收藏
分享
10-13 12:53
已编辑
湖北工业大学 前端工程师
小海c:包装一下,第一个感觉是字节青训营的那个,后面那个是黑马的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务