zoukankan      html  css  js  c++  java
  • hdoj1176 免费馅饼(dp 数塔)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1176

    思路:

    这道题不复杂,很明显是个dp题,数据比较大,搜索应该会超时,想到如何初始化,注意细节就差不多了。定义dp数组,边输入边初始化,dp[i][j]表示第i秒j处的掉落馅饼个数。dp过程从最后一秒逆向进行更方便,过程中dp[i][j]表示逆向到第i秒j处得到馅饼的最大值。有个坑点:最后输入的一组数据的时间不一定是最后一秒,我在这wa了一发。详见代码:

     1 #include<bits/stdc++.h>
     2 using namespace std;
     3 
     4 int n,x,t,tt,dp[100005][15];
     5 
     6 int main(){
     7     while(scanf("%d",&n)!=EOF&&n){
     8         memset(dp,0,sizeof(dp));
     9         tt=0;
    10         while(n--){
    11             scanf("%d%d",&x,&t);
    12             if(t>tt) tt=t;
    13             dp[t][x]++;
    14         }
    15         for(int i=tt-1;i>=0;i--)
    16             for(int j=0;j<=10;j++){
    17                 if(j==0) dp[i][j]+=max(dp[i+1][j],dp[i+1][j+1]);
    18                 else if(j==10) dp[i][j]+=max(dp[i+1][j-1],dp[i+1][j]);
    19                 else dp[i][j]+=max(dp[i+1][j-1],max(dp[i+1][j],dp[i+1][j+1]));
    20             }
    21         printf("%d
    ",dp[0][5]);
    22     }
    23     return 0;
    24 }
  • 相关阅读:
    HDU 2586 How far away?
    UVAlive 5796 Hedge Mazes
    HDU 4975 A simple Gaussian elimination problem.
    Poj 1149 PIGS
    HDU 3416 Marriage Match IV
    HDU 4912 Paths on the tree
    HDU 3277 Marriage Match III
    終於記起了帳號密碼
    codeforces194a
    codeforces195c
  • 原文地址:https://www.cnblogs.com/FrankChen831X/p/10393303.html
Copyright © 2011-2022 走看看