hdu 1176——免费馅饼

48 篇文章 0 订阅

最开始的时候从前向后算的,写的很麻烦,而且一直没找到错误在哪。。
从后往前算很容易
代码如下:

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

int dp[11][100005];

int main()
{
//    freopen("data.txt","r",stdin);
    int n;
    while(scanf("%d",&n)&&n){
        memset(dp,0,sizeof(dp));
        int tmax=0;
        for(int i=0;i<n;++i){
            int a,b;
            scanf("%d%d",&a,&b);
            dp[a][b]++;
            tmax=max(tmax,b);
        }
        for(int i=tmax;i>=0;--i){
            for(int j=0;j<=10;++j){
                int l=max(j-1,0);
                int r=min(j+1,10);
                int tmp=0;
                for(int k=l;k<=r;++k){
                    tmp=max(tmp,dp[k][i+1]);
                }
                dp[j][i]=dp[j][i]+tmp;
            }
        }
        printf("%d\n",dp[5][0]);
    }
    return 0;
}

从前往后算的代码还没有找到错在哪,先放在这里

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

struct Cake
{
    int T;
    int x;
    bool operator < (const Cake &a) const{
        if(T==a.T)return x<a.x;
        return T< a.T;
    }
};

int dp[15][100005];
Cake cake[100005];
int rec[100005];

int main()
{
//    freopen("data.txt","r",stdin);
    int n;
    while(scanf("%d",&n)!=EOF&&n){
        cake[0].T=0;
        cake[0].x=5;
        rec[0]=0;
        for(int i=1;i<=n;){
            int a,b;
            scanf("%d%d",&a,&b);
            if(a>10||a<0){
                    n--;
                continue;
            }
            cake[i].x=a;
            cake[i].T=b;
            rec[i]=cake[i].T;
            i++;
        }
        sort(cake+1,cake+n+1);
        sort(rec+1,rec+n+1);
        int tot=unique(rec,rec+n+1)-rec;
        memset(dp,-1,sizeof(dp));
        dp[5][0]=0;
        int t=0;
        int ans=0;
        for(int i=1;i<=n;++i){
            int step=0;
            if(cake[i].T>cake[i-1].T){
                t++;
                for(int j=0;j<=10;++j){
                    dp[j][t]=dp[j][t-1];
                }
            }
            int pos=cake[i].x;
            if(cake[i].T==cake[i-1].T&&cake[i].x==cake[i-1].x&&dp[pos][t]!=-1){
                dp[pos][t]++;
                ans=max(ans,dp[pos][t]);
                continue;
            }
            step=rec[t];
            for(int j=max(0,5-step);j<=min(10,5+step);++j){
                dp[j][t]=max(0,dp[j][t]);
            }
            step=rec[t]-rec[t-1];
            int l=max(pos-step,0);
            int r=min(pos+step,10);
            for(int j=l;j<=r;++j){
                if(dp[j][t-1]==-1)continue;
                dp[pos][t]=max(dp[pos][t],dp[j][t-1]+1);
            }
            ans=max(ans,dp[pos][t]);
        }
        if(t!=tot-1)tot=1/0;
        printf("%d\n",ans);
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值