码迷,mamicode.com
首页 > 其他好文 > 详细

hdu 4301(基本dp)

时间:2014-07-18 14:03:46      阅读:226      评论:0      收藏:0      [点我收藏+]

标签:style   blog   color   io   for   代码   

题意:就是给你一块2*n的巧克力,让你把它分成x块,并且每一个单位的巧克力各不相同,问有多少种分法?

分析:用dp[i][j][k],表示到巧克力的第二列时,巧克力被分成了j快,k用来表示第i列上下两块是分开的还是在一起的,在纸上把所有的情况画一下,于是就得到状态方程:

dp[i][j][0]=(dp[i-1][j][1]*2+dp[i-1][j][0]+dp[i-1][j-1][0]+dp[i-1][j-1][1])%mod;

dp[i][j][1]=(dp[i-1][j][1]+dp[i-1][j-1][0]*2+dp[i-1][j-1][1]*2+dp[i][j][1]+dp[i-1][j-2][0]+dp[i-1][j-2][1])%mod;

 

代码实现:

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

#define mod  100000007 

int dp[1005][2005][2];

void init()
{
    int i,j;
    memset(dp,0,sizeof(dp));
    dp[1][1][0]=1;
    dp[1][2][1]=1;

    for(i=1;i<=1000;i++)
        for(j=1;j<=2000;j++)
        {
            if(dp[i][j][0]==0)
             dp[i][j][0]=(dp[i-1][j][1]*2+dp[i-1][j][0]+dp[i-1][j-1][0]+dp[i-1][j-1][1])%mod;

            if(dp[i][j][1]==0)
            {
                dp[i][j][1]=(dp[i-1][j][1]+dp[i-1][j-1][0]*2+dp[i-1][j-1][1]*2)%mod;

                if(j-2>=0)
                {
                    dp[i][j][1]=(dp[i][j][1]+dp[i-1][j-2][0]+dp[i-1][j-2][1])%mod;
                }
            }
        }
}

int main()
{
    init();

    int T,n,m;

    scanf("%d",&T);
    while(T--)
    {
        scanf("%d%d",&n,&m);
        printf("%d\n",(dp[n][m][0]+dp[n][m][1])%mod);
    }
    return 0;
}

hdu 4301(基本dp),布布扣,bubuko.com

hdu 4301(基本dp)

标签:style   blog   color   io   for   代码   

原文地址:http://www.cnblogs.com/jiangjing/p/3852914.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!