首页 > 其他 > 详细

UVa11420 - Chest of Drawers

时间:2014-02-02 18:57:08      阅读:550      评论:0      收藏:0      [点我收藏+]

Problem D
Chest of Drawers 
Input: 
Standard Input

Output: Standard Output

 

bubuko.com,布布扣

Figure 1: A chest of drawers

A chest of drawers means a wardrobe which has many drawers aligned vertically as shown in the figure on the left. Although this is useful furniture, some problems arise when all the drawers need have provisions of locking - that is sometimes a drawer is not secured even if it is locked. For example assume that the third drawer from the top is locked but the drawer immediately above it is not locked. Then the drawer that is locked is also not secured because one can access it by pulling out the drawer immediately above it.

In a chest of n drawers, there are a number of ways to ensure that exactly s drawers are secure. For example for the chest of drawers shown on the left, exactly four drawers can be secured in six ways. These six ways are shown in Figure 2.

 

Given the value of n and s, your job is to find out in how many ways they can be secured.

 

 

bubuko.com,布布扣

 

bubuko.com,布布扣

 

bubuko.com,布布扣

 

bubuko.com,布布扣

 

bubuko.com,布布扣

 

bubuko.com,布布扣

Figure 2: In this figure L means that the drawer is locked and U means that the corresponding drawer is unlocked. And here all six locking combinations are shown which ensures that exactly four drawers are secured. Letters correspondingthe secured drawers are boldfaced.

 

Input

The input file contains at most 5000 lines of inputs.

 

Each line contains two integers n and s (1 ≤ n ≤ 65 and 0 ≤ s ≤ 65). Here n is the total number of drawers and s is the number of drawers that needs to be secured.

 

Input is terminated by a line containing two negative numbers. This input should not be processed.

 

Output

For each line of input produce one line of output. This line contains an integer which denotes in how many, s drawers out of the n drawers can be secured.

 

Sample Input                            Output for Sample Input

6 2

6 3

6 4

-1 -1

16

9

6

 





水题不解释:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <vector>
#include <string>
#include <algorithm>
#include <queue>
using namespace std;
typedef long long ll;
int n,s;
ll dp[70][70][2];
ll dfs(int dep,int seq,int last){
    if(dep==n) return seq==s;
    if(dp[dep][seq][last]!=-1) return dp[dep][seq][last];
    ll ans = 0;
    if(last==0){
        ans += dfs(dep+1,seq,1)+dfs(dep+1,seq,0);
    }else{
        ans += dfs(dep+1,seq+1,1)+dfs(dep+1,seq,0);
    }
   // cout<<ans<<endl;
    return dp[dep][seq][last] = ans;

}
int main(){

    while(~scanf("%d%d",&n,&s)){
        if(n<0&&s<0) break;
        memset(dp,-1,sizeof dp);
        cout<<dfs(1,0,0)+dfs(1,1,1)<<endl;
    }
    return 0;
}


UVa11420 - Chest of Drawers

原文:http://blog.csdn.net/mowayao/article/details/18895537

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!