求助只有50分
查看原帖
求助只有50分
267359
汪之常清楼主2020/7/30 14:48
#include<bits/stdc++.h>
using namespace std;
long long int a[100005],b[100005],dp[10005][10005];
int main(){
	int n,m;
	cin>>n>>m;
	for(int i=1;i<=m;i++)
		cin>>a[i]>>b[i];
	for(int i=1;i<=m;i++)
		for(int j=1;j<=n;j++)
		{
			if(j-a[i]>=0)
				dp[i][j]=max(dp[i-1][j],dp[i-1][j-a[i]]+a[i]*b[i]);
			else
				dp[i][j]=dp[i-1][j];
		}
	cout<<dp[m][n];
	return 0;
}
2020/7/30 14:48
加载中...