题目相关

题目描述

把 m个同样的苹果放在 n个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法。(5,1,1 和 1,1,5 是同一种方法)

输入格式

第一行是测试数据的数目 t,以下每行均包括二个整数 m和 n,以空格分开。

输出格式

对输入的每组数据 m和 n,用一行输出相应的结果。

输入输出样例

输入1

1

7 3

输出 1

8

输入 2

3
3 2
4 3
2 7

输出 2

2
4
2

说明/提示

对于所有数据,保证:\(1\leq m,n\leq 10,0 \leq t \leq 20\)。

原题链接

P2386 放苹果 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

分析

首先阅读题目,发现这题特殊在有的盘子能够空着不放。那么,分类讨论下,对于摆放的情况,就有可能出现所有盘子都有苹果或者是有盘子空着不放两种情况。

我们先设计这样一个函数fun(m,n)他的作用就是返回m个苹果放n个盘子中的方法数。接着,继续来讨论苹果的分配情况。

首先,如果苹果的数量少于盘子的数量,那么最多也就用上和苹果数量相同的盘子,剩下的盘子就用不上了。那么就相等于,m个苹果放在m个盘子中的分法。

接着,如果苹果数量比盘子数量多,那么就会出现最开始讨论的两种情况,一是每个盘子都有苹果,二是有的盘子空着不放。那么只要分别求出这两种情况对应的放法数,两者相加就能得到答案了。

先考虑下,每个盘子都放有苹果的情况,这样的话,每个盘子中就至少会有一个苹果存在,那么剩下的苹果分配放法就是盘子放满的放法数。\(fun(m,n)放满=fun(m-n,n)\)。

再来考虑。有盘子会空着不放的情况。他有可能是一个空盘,或两个空盘,或更多的空盘。而不论空几个盘子,他们都至少会空出一个盘子出来,那么这个空出来的盘子就没用了,也就相当于把苹果分配到n-1个盘子中。\(fun(m,n)有空盘=fun(m,n-1)\)。

由此,总结下:

\[\begin{equation}
fun(m,n)=\left\{
\begin{array}{rcl}
fun(m,m) & & {m<n}\\
fun(m-n,n)+fun(m,n-1) & & {m\ge n}
\end{array}
\right.
\end{equation}
\]

这样一分析,就能发现很明显的递归过程了。递归实现的两个要点1. 递归过程 2. 终止条件。递归过程有了,那么再来想想终止条件应该是什么,观察我们找到的解决方法,发现是苹果的数量和盘子的数量在不断减少,那么肯定是不可能无止境的少下去的,那么就想想少到什么时候会有显而易见的答案呢?盘子如果,只有一个,那么肯定就只有一种放法,苹果只有一个或者说零个,那么也只有一种放法。由此,就得到了递归的终止条件。再整合下:

\[\begin{equation}
fun(m,n)=\left\{
\begin{array}{rcl}
1 & & m = 0 \| m=1 \| n=1 \\
fun(m,m) & & {m<n}\\
fun(m-n,n)+fun(m,n-1) & & {m\ge n}
\end{array}
\right.
\end{equation}
\]

代码实现

#include<iostream>
using namespace std;
int t,M,N;
int apple(int m,int n){
if(m==1||n==1||m==0){// 终止条件
return 1;
}
if(m>=n){//苹果比盘子多
return apple(m,n-1)+apple(m-n,n);
}else{//苹果比盘子少
return apple(m,m);
} }
int main(){
cin>>t;
for(int i=0;i<t;i++){
cin>>M>>N;
cout<<apple(M,N)<<'\n';
}
return 0;
}

视频链接

https://www.bilibili.com/video/BV1ep4y1r7an

【递归】P2386放苹果的更多相关文章

  1. 洛谷——P2386 放苹果

    P2386 放苹果 题目背景 (poj1664) 题目描述 把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分发(5,1,1和1,1,5是同一种方法) 输入输出格式 输入 ...

  2. 洛谷 P2386 放苹果

    P2386 放苹果 题目背景 (poj1664) 题目描述 把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分发(5,1,1和1,1,5是同一种方法) 输入输出格式 输入 ...

  3. P2386 放苹果

    题目背景 (poj1664) 题目描述 把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分发(5,1,1和1,1,5是同一种方法) 输入输出格式 输入格式: 第一行是测试 ...

  4. poj1664放苹果(递归)

    题目链接:http://poj.org/problem?id=1664 放苹果 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: ...

  5. 放苹果(poj1664递归)

    ti放苹果 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 24392   Accepted: 15513 Descripti ...

  6. 递归--练习4--noi666放苹果

    递归--练习4--noi666放苹果 一.心得 写出状态后勇敢假设 二.题目 666:放苹果 总时间限制:  1000ms 内存限制:  65536kB 描述 把M个同样的苹果放在N个同样的盘子里,允 ...

  7. poj 1664放苹果(递归)

    放苹果 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 37377   Accepted: 23016 Description ...

  8. poj 1664 放苹果 递归

    题目链接: http://poj.org/problem?id=1664 题目描述: 有n个苹果,m个盒子,盒子和苹果都没有顺序,盒子可以为空,问:有多少种放置方式? 解题思路: 当前有n个苹果,m个 ...

  9. oj放苹果

    题目描述 把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法?(用K表示)5,1,1和1,5,1 是同一种分法. 输入 每个用例包含二个整数M和N.0<=m< ...

随机推荐

  1. vue基础题

    一.对于MVVM的理解? MVVM 是 Model-View-ViewModel 的缩写. Model代表数据模型,也可以在Model中定义数据修改和操作的业务逻辑. View 代表UI 组件,它负责 ...

  2. POWER BI 基于 ODBC 数据源的配置刷新-以Amazon Redshift为例

    POWER BI 基于 ODBC 数据源的配置刷新-以Amazon Redshift为例 Powerbi 有多种数据源连接,可以使用它们连接到不同数据源. 如果在 Power BI Desktop 的 ...

  3. React Native学习记录

    1.端口问题 在调试的时候,监听的是8081端口.如果被占用,会报错,并且在reload的时候导致app直接崩掉. 2.插件网站收集 https://nativebase.io/ https://js ...

  4. sql server的bcp指令

    有时需要允许bcp指令 -- 允许配置高级选项EXEC sp_configure 'show advanced options', 1GO-- 重新配置RECONFIGUREGO-- 启用xp_cmd ...

  5. 开源抓包工具PowerSniff(支持lua,c语言作为脚本实时分析)

    做这个程序的意图是wireshark插件编写复杂(虽然也支持lua),而轻量级的工具如smartsniff,minisniff不支持插件化数据分析,各种工具用下来或多或少不顺手.以前写的外挂也都是手工 ...

  6. 关于django python manage.py startapp 应用名 出错异常原因

    如题,在控制台运行python manage.py startapp sales 建立一个应用报错异常 1.应用名不能包含下划线等字符 所以app-demo 不能作为应用名被定义 2.manage.p ...

  7. node目录

    1 [了解nodejs] 1.1 [node简介] 1.2 [node的特点] 1.3 [如何安装] 1.4 [如何运行] 2 [es6--基本语法] 2.1 [变量的解构赋值] 2.2 [解构赋值] ...

  8. js下 Day07、DOM案例

    一.折叠菜单 效果图: 功能思路分析: 功能一:数据渲染 \1. 模拟数据,一级数据为数组套对象的形式,二级数据为数组: \2. 先渲染一级数据,然后再嵌套渲染二级数据(map().join('')) ...

  9. 基于 WebRTC 的 RTSP 视频实时预览

    简介 背景 由于项目需要,需要使用摄像头预览功能,设备型号为海康威视.目前已存在的基于 FFmpeg 的方案延迟都太高,所以项目最终选择基于此方案. 方案 方案选用为基于 WebRTC 的视频即时通讯 ...

  10. java基础:switch语句应用,循环的详细介绍以及使用,附练习案列

    1. switch语句 1.1 分支语句switch语句 格式 switch (表达式) { case 1: 语句体1; break; case 2: 语句体2; break; ... default ...