专题三 Problem G

一、题目编号:
          1007
二、简单题意:
       馅饼掉落在gameboy身旁的10米范围内。gameboy每秒种只有在移动不超过一米的范围内接住坠落的馅饼。为了使问题简化,假设在接下来的一段时间里,馅饼都掉落在0-10这11个位置。开始时gameboy站在5这个位置,因此在第一秒,他只能接到4,5,6这三个位置中其中一个位置上的馅饼。问gameboy最多可能接到多少个馅饼?(假设他的背包可以容纳无穷多个馅饼)
三、解题思路形成过程
        dp[i][j]表示第i秒第j位置有多少个馅饼,把所有馅饼都填入矩阵中,这样我只要从底往上走,走到最上面一层,找到所走过的位置中馅饼之数最大的那个就是我们所求结果。
四、感想
        前面做题还挺简单,最近做题感觉动态规划越做越难了,参考别人的博客还懵懵懂懂的状态。。好晕。。 敲打
五、AC代码
#include<stdio.h>
 #include<cstring>
 #include<algorithm>
 using namespace std;
 int dp[100005][12];
 int main()
 {
     int n,i,j,maxt;
     int x,t;
     while(scanf("%d",&n),n)
     {
         maxt=0;
         memset(dp,0,sizeof(dp));
         for(i=0;i<n;i++)
         {
             scanf("%d%d",&x,&t);
             dp[t][x]++;
             if(maxt<t)  maxt=t;
         }
         for(i=maxt-1;i>=0;i--)
         {
             dp[i][0]+=max(dp[i+1][1],dp[i+1][0]);
             for(j=1;j<11;j++)
             {
                 dp[i][j]+=max(max(dp[i+1][j-1],dp[i+1][j]),dp[i+1][j+1]);
             }
         }
         printf("%d\n",dp[0][5]);
     }
     return 0;
 }

你可能感兴趣的:(专题三 Problem G)