01背包 有N元求取K件是的w[i]*v[i]和最大
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int maxn = 30000 + 10;
int n,m;
int v[maxn];
int p[maxn];
int dp[maxn];///用dp[i]表示花费i元的最优解。
void solve()
{
scanf("%d%d",&n,&m);
for(int i = 1;i<=m;i++)
{
scanf("%d%d",&v[i],&p[i]);
}
for(int i =1;i<=m;i++)
{
for(int j = n;j;j--)
{
if(j>v[i])
{
dp[j] = max(dp[j],dp[j-v[i]] +v[i]*p[i]);///滚动数组倒推更新
}else
{
dp[j] = dp[j];
}
}
}
printf("%d\n",dp[n]);
}
int main()
{
solve();
return 0;
}
滚动数组
最新推荐文章于 2023-08-11 08:19:11 发布