HDOJ 1176 免费馅饼

26 篇文章 0 订阅
18 篇文章 0 订阅

方程比较简单的DP。

dp[t][x] = cnt[t][x] + max(dp[t+1][x], dp[t+1][x+1], dp[t+1][x-1])

总结:开始写成记忆化搜索爆栈了,然后发现 t 时刻完全可以由 t+1 推出,所以改成用循环来推就 AC 了。

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

const int maxn = 102000;
int dpa[maxn][11];
int pie[maxn][11];
int n, maxt;
//记忆化搜索会爆栈
//int dp(int t, int x)
//{
//    if(dpa[t][x] != -1) return dpa[t][x];
//    if(t == maxt) return dpa[t][x] = pie[t][x];
//    int ret = dp(t+1,x);
//    if(x > 0 && dp(t+1,x-1) > ret) ret = dpa[t+1][x-1];
//    if(x < 10 && dp(t+1,x+1) > ret) ret = dpa[t+1][x+1];
//    ret += pie[t][x];
//    return dpa[t][x] = ret;
//}

int main()
{
    while(cin >> n && n != 0) {
        memset(pie, 0, sizeof(pie));
        maxt = 0;
        for(int i = 0; i < n; i++) {
            int x, t;
            cin >> x >> t;
            if(t > maxt) maxt = t;
            pie[t][x]++;
        }
        memset(dpa, -1, sizeof(dpa));
        for(int i = 0; i < 11; i++)
            dpa[maxt][i] = pie[maxt][i];
        for(int i = maxt-1; i >= 0; i--) {
            for(int j = 0; j < 11; j++) {
                int tmp = dpa[i+1][j];
                if(j+1 < 11 && dpa[i+1][j+1] > tmp) tmp = dpa[i+1][j+1];
                if(j > 0 && dpa[i+1][j-1] > tmp) tmp = dpa[i+1][j-1];
                dpa[i][j] = pie[i][j] + tmp;
            }
        }
        cout << dpa[0][5] << endl;
    }

    return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值