2 条题解
-
0
#include <stdio.h> #include <iostream> using namespace std; int w[105], val[105]; int dp[1005]; int main() { int t,m,res=-1; scanf("%d%d",&t,&m); for(int i=1;i<=m;i++) { scanf("%d%d",&w[i],&val[i]);//输入 } for(int i=1;i<=m;i++) { for(int j=t;j>=0;j--) //01背包 { if(j>=w[i])//动态规划 { dp[j]=max(dp[j-w[i]]+val[i], dp[j]);//状态转移方程 } } } printf("%d",dp[t]);//输出 return 0; }
- 1
信息
- ID
- 566
- 时间
- 1000ms
- 内存
- 256MiB
- 难度
- 3
- 标签
- (无)
- 递交数
- 36
- 已通过
- 21
- 上传者