码迷,mamicode.com
首页 > 其他好文 > 详细

hdu 4976 A simple greedy problem.

时间:2015-07-15 19:24:40      阅读:137      评论:0      收藏:0      [点我收藏+]

标签:

题意:

有n个小兵,每个小兵有a【i】血量,第一个人每次只能对一个小兵砍一滴血,第二个人每次对所有生存的小兵砍一滴血。最后看第一个人最多可以砍杀几个小兵。


思路:

这个就是游戏中所说的垫刀问题。首先是不一样的越多那么第一个人所补得刀数就越多。

那么就要考虑要多少刀把当前的小兵的血量砍得和别人不一样。

用W【i】表示砍了i刀之后与其他的血量不一样的原始血量

用dp[i][j],表示进行了i组攻击(第一个攻击一次,第二个攻击一次,称为一组),第一个留有j次攻击,最多能杀死的小兵数目。

那么在第i组攻击的时候j的范围是【0,i+1】 ,因为第一个人可以有i+1次的机会

那么dp转移方程就是 dp【i+1】【t】 = max(dp【i】【j】+1,dp【i+1】【t】)(t = i+ j +1 -w[i+1] )


#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;

#define N 1111
int n;
int a[N];
int dp[N][N];
int w[N];

int main(){
    int T;
    int cas = 0 ;
    scanf("%d",&T);
    while(T--){
    	scanf("%d",&n);
    	memset(w,-1,sizeof(w));
    	for(int i=1;i<=n;i++){
    		scanf("%d",&a[i]);
    	}

    	sort(a+1,a+n+1);
//求a【i】边的不一样需要补多少刀
        for(int i=1;i<=n;i++){
        	for(int j=a[i];j>0;j--){
               if(w[j]==-1){
               	 w[j] = a[i];
               	 break;
               }
        	}
        }
        for(int i=1;i<=a[n];i++){
            printf("%d %d\n",w[i],i);
        }


        memset(dp,-1,sizeof(dp));

        dp[0][0]=0;
        for(int i=0;i<a[n];i++){
        	for(int j = 0;j<=i+1;j++){
        		if(dp[i][j]!=-1){
                   dp[i+1][j+1] = max(dp[i+1][j+1],dp[i][j]);
                   int ok = j+i+1 - w[i+1];
                   if(w[i+1]!=-1&&ok>=0){
                   	dp[i+1][ok] = max(dp[i+1][ok],dp[i][j]+1);
                   }
        		}

        	}
        }
        /*
        for(int i = 0;i<=a[n];i++)
        {
        for(int j = 0; j <= a[n] ; j ++){
            printf("%2d ",dp[i][j]);
        }
        puts("");
        }
        */
        int ans = 0;
        for(int j = 0; j <= a[n] ; j ++)
            ans = max(ans, dp[a[n]][j]);
        printf("Case #%d: %d\n",++cas,ans);
    }

}


版权声明:都是兄弟,请随意转载,请注明兄弟是谁

hdu 4976 A simple greedy problem.

标签:

原文地址:http://blog.csdn.net/u013076044/article/details/46895147

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!