30分求调

P1048 [NOIP2005 普及组] 采药

改动放在注释里面了哈 ``` #include<bits/stdc++.h> using namespace std; int w[105],c[105],dp[105][1005]; int main(){ int m,n; cin>>m>>n; for(int i=1;i<=n;i++){ cin>>w[i]>>c[i]; } for(int i=1;i<=n;i++){ for(int j=0;j<=m;j++){ // 修改为从0开始,保证所有状态都可达 if(w[i]<=j){ // 修改为小于等于,保证能选择该物品 dp[i][j]=max(c[i]+dp[i-1][j-w[i]],dp[i-1][j]); } else { dp[i][j] = dp[i-1][j]; // 添加else分支,处理无法选择该物品的情况 } } } cout<<dp[n][m]; return 0; } ```
by Sunny___little @ 2023-09-24 11:50:26


|