PKU2411

#include < string .h >
#include 
< stdio.h >

int  m, n;
__int64 f[
12 ][ 2048 ];
__int64 g[
12 ][ 12 ];

void  DFS( int  i,  int  j,  int  j2,  int  m2)
{
    
if(m2 == m)
        f[i
+1][j2]+=f[i][j];
    
else if((j2&(1<<m2))==0)
    

        DFS(i,j,j2 
| (1<<m2),m2+1);
        
if(m2<m-1 && (j2&(1<<(m2+1)))==0)DFS(i,j,j2,m2+2);
    }

    
else
    
{
        DFS(i,j,j2
&~(1<<m2),m2+1);
    }

}



int  main()
{    

    
{
        
for(m=1;m<=11;m++)
        
{

        
int i, j;
        memset(f,
0,sizeof(f));
        f[
0][0]=1;
        
for (i=0; i<11; i++)
        
{
            
for (j=0; j<(1<<m); j++)
                
if(f[i][j])
                    DFS(i,j,j,
0);

            g[i
+1][m]=f[i+1][0];
        }

    
//    printf("(%d,%d)=%I64d   \n",n,m,g[n][m]);
        }

    
//    printf("\n");
    }

    
while(scanf("%d%d",&n,&m)==2)
    
{
        
if(m==0 && n==0)break;
        printf(
"%I64d\n",g[n][m]);
    }

    
return 0;
}
    

你可能感兴趣的:(pku)