Fighting
Time Limit: 1000MS Memory limit: 65536K
题目描述
怒海争锋是一个新游戏,类似于星际争霸。在这个游戏中,敌人建造防御塔,血量为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
提示
背包问题,以时间为j ,计算每一个j时的最大伤害
来源
xfl
示例程序
#include <stdio.h>
#include <string.h>
int p[100000] ;
int main()
{
int i , j , n , m , l , k , ti[40] , li[40] ;
while(scanf("%d %d", &n, &l)!=EOF)
{
memset(p,0,sizeof(p));
for(i = 0 ; i < n ; i++)
scanf("%d %d", &ti[i], &li[i]);
k = 1 ;
while(k++)
{
for(i = 0 ; i < n ; i++)
{
for(j = ti[i] ; j <= k ; j++)
{
if(p[j] < p[j - ti[i] ] + (j-ti[i])*li[i] )
p[j] = p[j - ti[i] ] + (j-ti[i])*li[i] ;
}
}
if(p[k] >= l)
{
printf("%d\n", k);
break;
}
}
}
}