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

hdu 1208 (DP)

編輯:C++入門知識

 


/*

 

 

 

DP ,有點水,直接代碼。

map[ i ][ j ]表示跳幾格   dp [ i ][ j ] 表示有幾種條法

當map[i][j]!=0時才能跳。。

2013-04-23

 

 

*/

 

 

 


[cpp]

#include"stdio.h"  
#include"string.h"  
typedef __int64 int64; 
#define min(x,y) x>y?y:x;  
int64 dp[35][35]; 
char map[35][35]; 
int main() 

    int i,j,n,t; 
    while(scanf("%d",&n)!=-1,n!=-1) 
    { 
        getchar(); 
        memset(dp,0,sizeof(dp)); 
        for(i=0;i<n;i++) 
            gets(map[i]); 
        dp[0][0]=1; 
        for(i=0;i<n;i++) 
        { 
            for(j=0;j<n;j++) 
            { 
                if(map[i][j]-'0')///這裡要判斷一下否則會多加  
                { 
                    t=map[i][j]-'0'+i;   
                    if(t<n) 
                        dp[t][j]+=dp[i][j]; 
                     
                    t=map[i][j]-'0'+j; 
                    if(t<n) 
                        dp[i][t]+=dp[i][j]; 
                } 
            } 
        } 
        printf("%I64d\n",dp[n-1][n-1]); 
    } 
    return 0; 

#include"stdio.h"
#include"string.h"
typedef __int64 int64;
#define min(x,y) x>y?y:x;
int64 dp[35][35];
char map[35][35];
int main()
{
 int i,j,n,t;
 while(scanf("%d",&n)!=-1,n!=-1)
 {
  getchar();
  memset(dp,0,sizeof(dp));
  for(i=0;i<n;i++)
   gets(map[i]);
  dp[0][0]=1;
  for(i=0;i<n;i++)
  {
   for(j=0;j<n;j++)
   {
    if(map[i][j]-'0')///這裡要判斷一下否則會多加
    {
     t=map[i][j]-'0'+i; 
     if(t<n)
      dp[t][j]+=dp[i][j];
     
     t=map[i][j]-'0'+j;
     if(t<n)
      dp[i][t]+=dp[i][j];
    }
   }
  }
  printf("%I64d\n",dp[n-1][n-1]);
 }
 return 0;
}

 

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