Hdu1176免費餡餅

//免費餡餅

#include<stdio.h>
#include<string.h>
#define MAXN 100010

int dp[MAXN][12],pile[MAXN][12];
//全局變量和靜態變量的存儲區域是在一起的,程序結束後由系統釋放。數據區的大小由系統限定,一般很大。
int max_is(int a,int b,int c);
int main(){
	int n,x,t,i,j,maxt;
	while(scanf("%d",&n)!=EOF&&n){
		memset(dp,0,sizeof(dp));
		memset(pile,0,sizeof(pile));
		maxt=0;
		for(i=0;i<n;i++){
			scanf("%d%d",&x,&t);
			pile[t][x+1]++;
			if(maxt<t) maxt=t;
		}
		for(i=1;i<=11;i++)
			dp[maxt][i]=pile[maxt][i];
		for(i=maxt-1;i>=0;i--){
			for(j=1;j<=11;j++){
				dp[i][j]=max_is(dp[i+1][j-1],dp[i+1][j],dp[i+1][j+1])+pile[i][j];//狀態轉移方程
			}
		}
		printf("%d\n",dp[0][6]);
	}
	return 0;
}
int max_is(int a,int b,int c){
	int t;
	t=(b>c?b:c);
	return a>t?a:t;
}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章