解题思路:该问题明显就是动态规划,限定的使用资源(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.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论