程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> Hdu1176免費餡餅

Hdu1176免費餡餅

編輯:C++入門知識

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;
}

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved