P1802 5倍经验日

https://www.luogu.com.cn/problem/P1802
在这里插入图片描述

思路

  • 前 i 个敌人用j瓶药时,瓶子够用时,花药和不花药(认输)的所有选法,和瓶子不够用时,认输和不大这个敌人时所有的选法

  •   if(j >= c)
      		{
          
          
      			f[i][j] = max(f[i-1][j - c] + b, f[i - 1][j] + a);
      		}
      		else
      		{
          
          
      			f[i][j] = max(f[i - 1][j] + a, f[i - 1][j]);
      		}
    

代码

#include<bits/stdc++.h> 
#define int long long
using namespace std;
signed main()
{
    
    
	int n, x, f[1005][1005] = {
    
    0};
	cin >> n >>x;
	for(int i = 1; i <= n; i ++)
	{
    
    
		int a, b, c;
		cin >> a>> b>>c;
		for(int j = x; j >= 0; j --)
		{
    
    
			if(j >= c)
			{
    
    
				f[i][j] = max(f[i-1][j - c] + b, f[i - 1][j] + a);
			}
			else
			{
    
    
				f[i][j] = max(f[i - 1][j] + a, f[i - 1][j]);
			}
		}
	}
	cout<<f[n][x]*5;
	return 0;
}

Supongo que te gusta

Origin blog.csdn.net/qq_34682765/article/details/118735814
Recomendado
Clasificación