解题思路:该问题明显就是动态规划,限定的使用资源(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语言程序设计教程(第三版)课后习题10.3 (C语言代码)浏览:711 |
WU-判定字符位置 (C++代码)浏览:1471 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:624 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:913 |
1124题解浏览:630 |
循环入门练习6 (C语言代码)浏览:1058 |
震宇大神的杀毒软件 (C语言代码)浏览:1162 |
C语言程序设计教程(第三版)课后习题7.5 (C语言代码)浏览:712 |
1052题解(链表操作)浏览:782 |
C语言程序设计教程(第三版)课后习题8.7 (C语言代码)浏览:852 |