解题思路:该问题明显就是动态规划,限定的使用资源(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 人评分
WU-输出九九乘法表 (C++代码)浏览:1654 |
WU-整数平均值 (C++代码)浏览:1237 |
printf基础练习2 (C语言代码)浏览:644 |
矩阵加法 (C语言代码)浏览:1719 |
A+B for Input-Output Practice (V) (C语言代码)浏览:459 |
1126题解浏览:578 |
杨辉三角 (C语言代码)浏览:484 |
Quadratic Equation (C语言代码)浏览:988 |
1197求助浏览:627 |
A+B for Input-Output Practice (IV) (C语言代码)浏览:503 |