解题思路:
代码前的思考:由于每一项的值都大于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分
29 人评分
数组输出 (C语言代码)错误???浏览:602 |
C语言训练-求PI* (C语言代码)浏览:637 |
三角形 (C++代码)递推浏览:825 |
简单的a+b (C语言代码)浏览:626 |
简单的a+b (C语言代码)浏览:529 |
【偶数求和】 (C语言代码)浏览:460 |
矩阵转置 (C语言代码)浏览:855 |
检查金币 (C语言代码)浏览:1504 |
C语言程序设计教程(第三版)课后习题6.6 (C语言代码)浏览:584 |
蛇行矩阵 (Java代码)浏览:693 |