您的位置:首页 > 其它

hdu1176 免费馅饼(塔形)

2014-05-17 21:54 204 查看
http://acm.hdu.edu.cn/showproblem.php?pid=1176

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

int s[100003][11],n,sum;

int Max(int a,int b,int c)
{
if(a<b)a=b;
if(a<c)a=c;
return a;
}
void dp()
{
int i,j;
for(i=sum;i>0;i--)
{
for(j=0;j<=10;j++)
{
if(j==0)s[i-1][j]+=Max(0,s[i][j],s[i][j+1]);
else if(j==10)s[i-1][j]+=Max(s[i][j-1],s[i][j],0);
else s[i-1][j]+=Max(s[i][j-1],s[i][j],s[i][j+1]);
}
}
printf("%d\n",s[0][5]);
}

int main()
{
int i,a,b;
while(scanf("%d",&n))
{
sum=0;
if(n==0)break;
fill(&s[0][0],&s[100002][11]+1,0);
for(i=0;i<n;i++)
{
scanf("%d%d",&a,&b);
s[b][a]++;
if(sum<b)sum=b;
}
dp();
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: