题目链接:
https://www.acwing.com/problem/content/description/1024/
#01背包
典型的二维 01 背包问题
但求“收服 C 个小精灵时皮卡丘的剩余最多体力值”时卡了一下
当时在想这二维费用怎么不平衡之类的,其实没有这么复杂
求出最大值后,就再遍历一遍,找出最小消耗的体力
代码
#include <iostream>
#include <algorithm>
using namespace std;
const int N = 1010, M = 510;
int n, V1, V2;
int f[N][M];
int main()
{
cin >> V1 >> V2 >> n;
for (int i = 0; i < n; i ++ )
{
int v1, v2;
cin >> v1 >> v2;
for (int j = V1; j >= v1; j -- )
for (int k = V2 - 1; k >= v2; k -- )
f[j][k] = max(f[j][k], f[j - v1][k - v2] + 1);
}
cout << f[V1][V2 - 1] << ' ';
int k = V2 - 1;
while (k > 0 && f[V1][k - 1] == f[V1][V2 - 1]) k -- ;
cout << V2 - k << endl;
return 0;
}