解题思路:
代码前的思考:由于每一项的值都大于0,所以我们要尽可能的多选,将问题转换成:给定一个序列,要求不能选取相邻的元素,问能获得的最大价值是多少?
1、分别记录每个点取或不取所形成的价值
2、取的话就等于上一项不取加上本项的价值
3、不取的话等于上一项取或者不取中的最大值
注意事项:
dp[i][0]:不取第i项的价值(i从0开始)
dp[i][1]:取第i项的价值
答案是最后一项取或不取的最大值
温馨提示,这是一类有代表性的问题,具体可以参考Leetcode上的打家劫舍问题系列
参考代码:
def get(c): #获得字符的价值 return ord(c)-ord('a')+1 s=input() n=len(s) dp=[[0,0] for i in range(n)] dp[0][1]=get(s[0]) for i in range(1,n): dp[i][0]=max(dp[i-1][0],dp[i-1][1]) # 不取,选上一项操作的最大值 dp[i][1]=dp[i-1][0]+get(s[i]) # 取这一项的话上一项只能不取了 print(max(dp[-1][0],dp[-1][1]))
0.0分
20 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复