ACM_递推题目系列之三放苹果(递推dp)
Problem Description:
把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法?(用K表示)5,1,1和1,5,1 是同一种分法。
Input:
第一行是测试数据的数目t(0 <= t <= 20)。以下每行均包含二个整数M和N,以空格分开。1<=M,N<=10。
Output:
对输入的每组数据M和N,用一行输出相应的K。
Sample Input:
2
8 6
7 3
Sample Output:
20
8
解题思路:
设f(m,n) 为m个苹果,n个盘子的放法数目,则先对n作讨论:
①当m<n:必定有n-m个盘子永远空着,去掉它们对摆放苹果方法数目不产生影响。即if(n>m) f(m,n) = f(m,m);
②当m>=n:不同的放法可以分成两类:含0的方案数,不含0的方案数:
1、含0的方案数,至少有一个盘子空着,即相当于f(m,n) = f(m,n-1);
2、不含0的方案数,所有盘子都有苹果,相当于可以从每个盘子中拿掉一个苹果,不影响不同放法的数目,即f(m,n) = f(m-n,n);
而总的放苹果的放法数目等于两者的和,即 f(m,n) =f(m,n-1)+f(m-n,n)。
递归出口条件说明:
当n==1时,所有苹果都必须放在一个盘子里,所以返回1;
当没有苹果可放(m==0)时,定义为1种放法;
递归的两条路,第一条n会逐渐减少,终会到达出口n==1;
第二条m会逐渐减少,因为n>m时,会return f(m,m),所以终会到达出口m==0.
为什么出口m==0呢?因为我们总是让m>=n来求解的,所以m-n>=0,让m=0时候结束。如果改为m=1,则可能出现m-n=0的情况(与条件不符)从而不能得到正确解。
AC代码一(递归写法):
#include<bits/stdc++.h>
using namespace std;
int fun(int m,int n){
if(m== || n==)return ;
if(m<n)return fun(m,m);
else return fun(m,n-)+fun(m-n,n);
}
int main(){
int t,m,n;
cin>>t;
while(t--){
cin>>m>>n;
cout<<fun(m,n)<<endl;
}
return ;
}
AC代码二(dp写法):
#include<bits/stdc++.h>
using namespace std;
int main(){
int t,m,n,dp[][];
cin>>t;
while(t--){
cin>>m>>n;//初始化,盘子有0个时,无论有多少个苹果,情况数都为0
for(int i=;i<=m;++i){dp[i][]=;dp[i][]=;}//盘子有1个时,苹果0个时定义为1种情况,其余也都是1种情况
for(int i=;i<=n;++i)dp[][i]=;//苹果0个时,定义为1种情况
for(int i=;i<=m;++i){
for(int j=;j<=n;++j){
if(i<j)dp[i][j]=dp[i][i];
else dp[i][j]=dp[i][j-]+dp[i-j][j];
}
}
cout<<dp[m][n]<<endl;
}
return ;
}
ACM_递推题目系列之三放苹果(递推dp)的更多相关文章
- POJ1664:放苹果(线性dp)
题目: http://poj.org/problem?id=1664 Description 把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法?(用K表示)5,1,1 ...
- OpenJudge 666:放苹果 // 瞎基本DP
666:放苹果 总时间限制: 1000ms 内存限制: 65536kB 描述 把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法?(用K表示)5,1,1和1 ...
- 666:放苹果(划分dp)
666:放苹果 查看 提交 统计 提问 总时间限制: 1000ms 内存限制: 65536kB 描述 把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法?(用K表示 ...
- ACM_递推题目系列之一涂色问题(递推dp)
递推题目系列之一涂色问题 Time Limit: 2000/1000ms (Java/Others) Problem Description: 有排成一行的n个方格,用红(Red).粉(Pink).绿 ...
- ACM_递推题目系列之二认错人(递推dp)
递推题目系列之二认错人 Time Limit: 2000/1000ms (Java/Others) Problem Description: 国庆期间,省城HZ刚刚举行了一场盛大的集体婚礼,为了使婚礼 ...
- POJ 1664 放苹果 (递推)
题目链接:http://poj.org/problem?id=1664 dp[i][j]表示i个盘放j个苹果的方案数,dp[i][j] 可以由 dp[i - 1][j] 和 dp[i][j - i] ...
- 九度oj 题目1160:放苹果
题目描述: 把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法?(用K表示)5,1,1和1,5,1 是同一种分法. 输入: 第一行是测试数据的数目t(0 <= t ...
- 刷题向》DP》放苹果 (normal)
这篇博客可能字数比较多,而且很难讲清楚,我会努力给你们讲清楚: 首先,放苹果是一道DP,之所以难,是因为很难想到,我的确有同学用三维数组做出来,然而三维的的确比二维好理解,但三维复杂度太高,虽然DP一 ...
- POJ 1664 放苹果 (递推思想)
原题链接:http://poj.org/problem?id=1664 思路:苹果m个,盘子n个.假设 f ( m , n ) 代表 m 个苹果,n个盘子有 f ( m , n ) 种放法. 根据 n ...
随机推荐
- 【NOIP2017】宝藏(状压DP)
题意: 思路:n<=12,考虑状压DP 生成树中深度相同的点可以一次性转移完毕 设dp[sta,i]为已转移完sta状态的点,当前深度为i的最小花费 dp[sta or v,i+1]=min(d ...
- Thinkphp5.0 的使用模型Model查询
Thinkphp5.0 的使用模型Model查询 一.查询多条记录 获取多个数据可以使用:select()方法和all()方法. 示例一:使用all()方法. //(1)筛选条件使用闭包函数 $res ...
- cache and database
This article referenced from http://coolshell.cn/articles/17416.html We all know that high concurren ...
- anaconda是个啥?
Anaconda具有跨平台(win/mac/linux).包管理(类似于pip).环境管理(类似于virtualenv)的特点,因此很适合快速在新的机器上部署Python环境 Anaconda利用工具 ...
- 004 ospf
r0(config)#router ospf 1 OSPF process 1 cannot start. There must be at least one "up" IP i ...
- VC++ 提示无法打开包括文件“iostream.h”怎么办
把 //#include "iostream.h" 改成 #include<iostream> using namespace std; ...
- webpack—入门
点击进入webpack官网.,开始教程时,建议先学习ES6语法,也请先观看本篇Windows符号介绍文章,当所有webpack内容学习完后,会有一个专门的介绍 webpack四个核心概念(从官网入门— ...
- 对json的爱恨情仇
本文回想了对json的爱恨情仇. C++有风险,使用需慎重. 本文相关代码在:http://download.csdn.net/detail/baihacker/7862785 当中的測试数据不在里面 ...
- libsqlite3.dylib与libsqlite3.0.dylib的差别
在我们加入数据库框架时,在搜索框中输入sqlitekeyword,以下列表区会显示libsqlite3.dylib,libsqlite3.0.dylib. 此时我们选择libsqlite3.0.dyl ...
- redis Database Eviction Policies Redis on Flash
Database Eviction Policies - Redis Enterprise Software | Redis Labs https://redislabs.com/redis-ente ...