zoukankan      html  css  js  c++  java
  • 算法题之放苹果

    题目描述
    把 M 个同样的苹果放在 N 个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法?
    注意:5、1、1 和 1、5、1 是同一种分法,即顺序无关。

    输入描述:
    输入包含多组数据。

    每组数据包含两个正整数 m和n(1≤m, n≤20)。


    输出描述:
    对应每组数据,输出一个整数k,表示有k种不同的分法。

    输入例子:
    7 3

    输出例子:
    8

    #include <iostream>
    using namespace std;
    int f(int m, int n)
    {
        // 递归出口:有0个苹果 || 只有1个盘子
        if (m == 0 || n == 1)
            return 1;
        if (n>m) // 盘子比较多,肯定有空盘子,去掉必空的盘子
            return f(m, m);
        else // 苹果比较多:
            // 1:至少有一个空盘子,拿掉这个空盘子
            // 2:每个盘子都有苹果,各拿掉一个苹果(极限是最少的有1个苹果)
            return f(m, n - 1) + f(m - n, n);
    }
    int main()
    {
        int m, n;
        while (cin >> m >> n)
            cout << f(m, n) << endl;
        return 0;
    }
    

      

  • 相关阅读:
    记一次centos 服务器中毒事件
    heatmap
    this
    购物车
    带标签的无缝轮播
    无缝轮播
    图片滚动百分百宽度
    选择排序
    冒泡排序
    tab标签页
  • 原文地址:https://www.cnblogs.com/shixiangwan/p/6735843.html
Copyright © 2011-2022 走看看