1Look2* 2021-11-09 19:37 采纳率: 100%
浏览 104
已结题

一个分糖果的c++编程

双十一的时候,小孟在网上抢购了很多糖果。糖果到手以后,他就纠结怎么分成好几天慢慢吃完,于是他决定列出所有分配方案。

比如他买了2个糖果,记为A和B,他就可以分配成

方案1.第一天{AB}

方案2.第一天{A} 第二天{B}

方案3.第一天{B} 第二天{A}

共3种分配方案,每个糖果之间看做是不同的,但是同一天内吃的糖果看做没有顺序。

请算出对于N个糖果,小孟一共有多少种分配的方案。
N<=15

输入样例:
2
3
4
输出样例:
3
13
75

  • 写回答

1条回答 默认 最新

  • 关注

    代码如下:

    #include <iostream>
    using namespace std;
    
    long long fact(int n)
    {
        long long s=1;
        int i;
        for(i=1;i<=n;i++)
            s*=i;
        return s;
    }
    
    long long Cnm(int n,int m)
    {
        return fact(n)/fact(m)/fact(n-m);
    }
    
    
    
    long long fun(int n)
    {
        long long s=0;
        int i;
        if(n == 1)
            return 1;
        else
        {
            for(i=1;i<n;i++)
                s += Cnm(n,i)*fun(n-i);
            return s+1;
        }
    }
    
    int main()
    {
        int n;
        while(1)
        {
            cin >> n;
            if (cin.eof()) break;
            cout << fun(n)<<endl;
        }
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月19日
  • 已采纳回答 11月11日
  • 创建了问题 11月9日

悬赏问题

  • ¥15 echarts动画效果失效的问题。官网下载的例子。
  • ¥60 许可证msc licensing软件报错显示已有相同版本软件,但是下一步显示无法读取日志目录。
  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
  • ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事:
  • ¥15 前置放大电路与功率放大电路相连放大倍数出现问题
  • ¥30 关于<main>标签页面跳转的问题
  • ¥80 部署运行web自动化项目
  • ¥15 腾讯云如何建立同一个项目中物模型之间的联系
  • ¥30 VMware 云桌面水印如何添加