20分
查看原帖
20分
1349424
Charlie_Nine楼主2024/11/7 18:58
#include<bits/stdc++.h>
using namespace std;
int n,m,a[110],b[20010],dp[20010];
int main(){
	for(int i=0;i<=n;i++){
		dp[i]=INT_MIN;
	}
	cin>>n>>m;
	for(int i=0;i<m;i++){
		cin>>a[i];
	}
	for(int i=0;i<n;i++){
		cin>>b[i];
	}
	dp[0]=0;
	for(int i=0;i<n;i++){
		for(int j=0;j<m;j++){
			if(i+a[j]>n)
				dp[n]=max(dp[n],dp[i]+b[i]);
			else
				dp[i+a[j]]=max(dp[i+a[j]],dp[i]+b[i]);
		}
	}
	cout<<dp[n];
	return 0;
}
2024/11/7 18:58
加载中...