上篇文章的优化以及启发思维
#include <iostream>
using namespace std;
const int Num = 1e3+20;
int dp[Num];
int va[Num];
int vo[Num];
int main()
{
int t;
int n, v;
cin >> t;
while (t--)
{
cin >> n >> v;
for (int i=1; i<=n; i++)
{
cin >> va[i];
}
for (int i=1; i<=n; i++)
{
cin >> vo[i];
}
// for (int i=0; i<=n; i++)
// {
for (int j=0; j<=v; j++)
{
// dp[i][j] = 0;
dp[j] = 0;
}
// }
for (int i=1; i<=n; i++)
{
for (int j=v; j>=0; j--)
{
// dp[i][j] = dp[i-1][j];
// if (j >= vo[i])
// {
// dp[i][j] = max(dp[i-1][j-vo[i]]+va[i], dp[i][j]);
// }
if (j >= vo[i])
{
dp[j] = max(dp[j-vo[i]]+va[i], dp[j]);
}
}
}
cout << dp[v] << endl;
}
return 0;
}