白色相簿的季节(递归)

题目描述

又到了白色相簿的季节。有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));
           //递归的条件,排列组合的占位思想
}
    
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值