hdu 1176 免费馅饼

//动态规划问题,数塔问题,从下往上进行递加

#include<stdio.h>

#include<string.h>
#define N 100000
int a[N+5][11];
int max1(int m,int n)
{
    if(m>n)
    return m;
    return n;
    }
int max2(int x,int y,int z)
{
    if(x>y)
    {
           if(x>z)
           return x;
           else
           return z;
           }
    else
    {
        if(y>z)
        return y;
        else
        return z;
        }
    }
int main()
{
    int n,i,j;
    while(scanf("%d",&n))
    {
    if(n==0)
    break;
    memset(a,0,sizeof(a));
    int count=0;
    for(i=0;i<n;i++)
    {
                    int x,T;
                    scanf("%d%d",&x,&T);
                    a[T][x]++;
                    if(T>count)
                    count=T;
                    }
                    for(i=count-1;i>=0;i--)
                    {
                                           if(i<=4)
                                           for(j=5-i;j<=5+i;j++)
                                           a[i][j]+=max2(a[i+1][j-1],a[i+1][j],a[i+1][j+1]);
                                           else
                                           {
                                               for(j=0;j<=10;j++)
                                               {
                                               if(j==0)
                                               a[i][j]+=max1(a[i+1][j],a[i+1][j+1]);
                                               else if(j==10)
                                               a[i][j]+=max1(a[i+1][j-1],a[i+1][j]);
                                               else
                                               a[i][j]+=max2(a[i+1][j-1],a[i+1][j],a[i+1][j+1]);
                                               }
                                               }
                                           }
                                     printf("%d\n",a[0][5]);
}
return 0;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值