Fighting 背包

题目描述

怒海争锋是一个新游戏,类似于星际争霸。在这个游戏中,敌人建造防御塔,血量为L。玩家有一个军事工厂,可以生产N种战斗舰艇。第i个战舰的生产时间为ti,这战舰每秒钟可以让塔损失血量为li。如果塔的寿命低于或等于0,玩家获胜。注意,在每一秒内,军事工厂只能选择一种战斗船生产或什么也不做。选择后的战斗舰艇生产时不可以同时生产。生产完一个再生产下一个。
 
你的任务是找出玩家赢得比赛的最少时间。 

输入

有多组输入。  
每组的第一行包含两个整数N(1≤N≤30)和L (1≤L≤330),N是军事工厂中有N种战舰,L是防御塔的血量。然后以下N行,每一行包含两个整数ti(1≤ti≤20)第i个战舰的生产时间和li(1≤li≤330)第i个战斗舰艇对塔造成的伤害。

输出

为每个测试用例输出一行。一个整数表示玩家赢得比赛的最少时间。

示例输入

1 1
1 1
3 100
1 10
3 20
10 100

示例输出

2
5

提示
#include<stdio.h>
int Max(int a,int b)
{
    return a>b?a:b;
}
int main()
{
    int n,l,i,k,time;
    int f[1000],ti[1000],li[1000];
    while(scanf("%d %d",&n,&l)!=EOF)
    {
        memset(f,0,sizeof(f));
           for(i=0;i<n;i++)
           {
               scanf("%d %d",&ti[i],&li[i]);
           }
           time=330;
            for(i=0;i<n;i++)
            for(k=ti[i];k<340;k++)
           {
            f[k]=Max(f[k],f[k-ti[i]]+(k-ti[i])*li[i]);
                if(f[k]>=l)
                {
                    if(k<time)
                    {
                        time=k;
                        break;
                    }
               }
           }
            printf("%d\n",time);
      }
      return 0;
}
当时实在没想出来状态转移方程,太弱了这是看了别人的代码才写出来的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值