题目描述
怒海争锋是一个新游戏,类似于星际争霸。在这个游戏中,敌人建造防御塔,血量为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;
}
当时实在没想出来状态转移方程,太弱了这是看了别人的代码才写出来的
#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;
}
当时实在没想出来状态转移方程,太弱了这是看了别人的代码才写出来的