Problem Description
为了使问题简化,假设在接下来的一段时间里,馅饼都掉落在0-10这11个位置。开始时gameboy站在5这个位置,因此在第一秒,他只能接到4,5,6这三个位置中期中一个位置上的馅饼。问gameboy最多可能接到多少个馅饼?(假设他的背包可以容纳无穷多个馅饼)
Input
Output
提示:本题的输入数据量比较大,建议用scanf读入,用cin可能会超时。
Example Input
6 5 1 4 1 6 1 7 2 7 2 8 3 0
Example Output
4
#include<stdio.h>
int a[100000][13]={0};
int sum[100000][13]={0};
int max2 (int a, int b, int c)
{
int max_abc;
max_abc=a;
if(b>max_abc)
{
max_abc=b;
}
if(c>max_abc)
{
max_abc=c;
}
return max_abc;
}
int main()
{
int i, j, n;
int x, t;
int k;
int max=0;
while(scanf("%d",&n),n)
{
memset(a,0,sizeof(a));
memset(a,0,sizeof(sum));
max=0;
for(i=0;i<n;i++)
{
scanf("%d%d",&x, &t);
a[t][x+1]++;
if(t>max)
{
max=t;
}
}
for(i=1;i<12;i++)
{
sum[max][i]=a[max][i];
}
for(i=max-1;i>=0;i--)
{
for(j=1;j<12;j++)
{
sum[i][j] = a[i][j] + max2 ( sum[i+1][j-1], sum[i+1][j], sum[i+1][j+1] );
}
}
printf("%d\n",sum[0][6]);
}
return 0;
}