01背包
查看原帖
01背包
1288602
Xianyujunzhu楼主2024/9/17 16:40

30分求解

#include<bits/stdc++.h>
using namespace std;
int t,m;
int w[105],v[105];
int dp[105][105];
int main(){
	cin>>t>>m;
	for(int i=1;i<=m;i++){
		cin>>w[i]>>v[i];
	}
	for(int i=1;i<=m;i++){
		for(int j=t;j>=0;j--){
			if(j>=w[i]){
				dp[i][j]=max(dp[i-1][j-w[i]]+v[i],dp[i-1][j]);
			}
			else{
				dp[i][j]=dp[i-1][j];
			}
		}
	}
	cout<<dp[m][t];
	return 0;
}
2024/9/17 16:40
加载中...