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

hdu2861(递推)

时间:2014-12-30 01:45:33      阅读:139      评论:0      收藏:0      [点我收藏+]

标签:

 

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2861

 

题意:n个板凳有m个人坐,求刚好将序列分成k段的方式。

 

分析:

    a[n][m][k]=a[n-1][m][k]+b[n-1][m][k-1];
    b[n][m][k]=a[n-1][m-1][k-1]+b[n-1][m-1][k];
    a[n][m][k]:表示有n个座位、m个人、分成k段、最后一个位置没有人的情况数;
    b[n][m][k]:表示有n个座位、m个人、分成k段、最后一个位置有人的情况数。

技术分享
#include <cstdio>
#include <cstring>
#include <cmath>
#include <iostream>
#include <algorithm>
#include <queue>
#include <cstdlib>
#include <stack>
#include <vector>
#include <set>
#include <map>
#define LL long long
#define mod 1000000007
#define inf 0x3f3f3f3f
#define N 100010
#define clr(a) (memset(a,0,sizeof(a)))
using namespace std;
LL a[205][205][21],b[205][205][21];
void init()
{
    for(int i=1;i<=200;i++)a[i][0][1]=1;
    b[1][1][1]=1;
    for(int i=2;i<=200;i++)
    {
        for(int j=1;j<=i;j++)
        {
            for(int k=1;k<=i&&k<=20;k++)
            {
                a[i][j][k]=a[i-1][j][k]+b[i-1][j][k-1];
                b[i][j][k]=a[i-1][j-1][k-1]+b[i-1][j-1][k];
            }
        }
    }
}
int main()
{
    int n,m,k;init();
    while(scanf("%d%d%d",&n,&m,&k)>0)
    {
        printf("%I64d\n",a[n][m][k]+b[n][m][k]);
    }
}
View Code

 

hdu2861(递推)

标签:

原文地址:http://www.cnblogs.com/lienus/p/4192738.html

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