解题思路:该问题明显就是动态规划,限定的使用资源(N元预算),每件商品选择买或者不买(0/1选择),给出商品数量;只需要使用动态规划经典思路,dp二位列表,dp[i][j]=dp[i-1][j](忽略该商品不买),dp[i][j]=max(dp[i-1][j],dp[i-1][j-v[i]]+v[i]*level[i])(可购买此商品,选择最大价值与等级积),注意v[i]*level[i]的这个地方应根据具体题目要求改变,这里是最大价值与等级积
注意事项:注意尽量用1开始的下标,不然容易搞混
参考代码:
a,b=map(int,input().split())
dp=[[0]*(a+1) for _ in range(b+1)]
for i in range(1,b+1):
value,level=map(int,input().split())
for j in range(1,a+1):
if j>=value:
dp[i][j]=max(dp[i-1][j],dp[i-1][j-value]+value*level)
else:
dp[i][j]=dp[i-1][j]
print(dp[b][a])
0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复