白色相簿的季节(递归)

题目描述

又到了白色相簿的季节。有n封信,竟然是n个男生送给他们各自女朋友的信!!!面对这n对情侣的信(1<=n<=18),狗哥因为难过而失去了理智,他在这时问你,把这n封信全部配送错有多少种方案。并且把这首《届かない恋》送给了你。

输入

第一行一个T,表示样例数
接下来T行,每行一个正整数n(1<=n<=18),表示n封信。

输出

对于每组样例,输出一个数,表示n封信全部配送错的方案数。

样例输入

2

2

3

样例输出

1

2

这是一个关于排列组合的题目,我是根据排列数学原理找到递归条件的;

转载别人关于递归的一点感悟:
1.先弄清楚递归的顺序。在递归的实现中,通常假设后续的调用已经完成,
在此基础上,才实现递归的逻辑。在该题中,我们假设已经求出的情况下,
再将第一个元素添加进去,再进行合并。
2.分析清楚递归的逻辑
3.考虑好递归的退出条件,也就是边界条件。

#include <stdio.h>
long long solution(int a);
int main()
{
    int T;
    scanf("%d",&T);
     while(T--) 
    {
            int n;
            scanf("%d",&n);
            printf("%lld\n",solution(n));
    }
    return 0;
}
long long solution(int n)
{
    if(n==1)
        return 0;
    else if(n==2)
        return 1;
    else if(n==3)
        return 2;
            //三个边界条件
    else
        return (n-1)*(solution(n-2)+solution(n-1));
           //递归的条件,排列组合的占位思想
}
    
 

猜你喜欢

转载自blog.csdn.net/yan_dan/article/details/78939070