m个苹果放入n个篮子
题目 :X个相同的苹果放入Y个篮子,
(1)篮子可以为空 ,篮子不同。 放法有C(X+Y-1,Y-1 );//
(2)篮子不可以为空,篮子不同.放法有C(X-1,Y-1) //插挡板法
分析有了这个组合公式,参考我的 求组合数程序即可解决问题。
(3)篮子可以为空,篮子相同。按上面程序求解 递推公式dp[i][j]=dp[j-i][i]+dp[j][i-1]
#if 0
/*
m个相同的苹果放入n个相同的篮子,篮子可以为空。
下面两种方法求解,动态规划和递归。但都须知:
dp[0][j]=0;含义为:j(j>0)个苹果放入0个篮子,没有地方放,放法为0.
dp[i][0]=1;0个苹果放入i个篮子,每个篮子都为空,放法为1.
dp[0][0]=1;当然,0个苹果放到0个篮子放法为1.即0!=1;
还有 dp[i][j],i>j时,即篮子数大于苹果数是dp[i][j]=dp[j][j],含义为 把2个苹果放到5个篮子的放法和把2个苹果放到2个篮子放法数相同。
*/
int dp[][];//全局,默认初始化为0
int n,m;
int main()
{ m=;n=;
int i,j;
//全局变量默认初始化为0可以无需初始化了。 // for (j=0;j<m;j++)//苹果 // {
// dp[0][j]=0;
// }
//可以再拆分,也无需初始化。
// for (i=0;i<n;i++)//篮子
// {
// dp[i][0]=1;
// }
dp[][] = ; for(i = ; i <= n; ++i)//篮子
for( j =; j <= m; ++j)//苹果
{
if(j>=i)
{
dp[i][j] = dp[i][j-i] + dp[i-][j];
cout<<"dp["<<i<<"]["<<j<<"] = dp["<<i<<"]["<<j-i<<"] + dp["<<i-<<"]["<<j<<"]";
cout<<":"<<dp[i][j]<<" = "<<dp[i][j-i]<<" + "<<dp[i-][j];
}
else
{
dp[i][j] = dp[j][j];
cout<<"dp["<<i<<"]["<<j<<"] = dp["<<j<<"]["<<j<<"]";
cout<<":"<<dp[i][j]<<" = "<<dp[j][j];
}
cout<<endl; }
cout<<dp[n][m]<<endl;
//}
return ;
}
#endif //递归求解
#if 0
int fun(int n,int m)
{
if (n==0&&m!=0)//篮子为空
return 0;
else if (m==0)
{
return 1;
}
else if (m>=n)
{
return fun(n,m-n)+fun(n-1,m);
}
else
return fun(m,m);
}
int main()
{
int n=,m=; cout<<fun(n,m)<<endl;
}
#endif
测试数据: 3 7 count=8
3 5 count=5

(4)篮子不可以为空,篮子相同。没有递推公式:但是dp[X][Y]=dp[X-Y][Y], 计算dp[X-Y][Y]可以用(3)中递推公式。
下面求解(4)的情况
//篮子不可以为空,即m>=n;
int count=;
int fun(int n,int m)
{
if (n==&&m!=)//篮子为空
count=;
else if (m==)
{
count=;
}
else if (m>=n)
{
count=fun(n,m-n)+fun(n-,m);
}
else
count=fun(m,m); return count;
} int main()
{
int n=,m=;
fun(n,m-n);
cout<<count<<endl;
}
//测试数据: 3,5 count=2;
3,7 count=4;
数学模型为正整数的分拆
详见组合数学书第二章
1、C(n,r) 从n个不同的球中取出r个,放进r个相同的 盒子中,不许空盒,有多少种放法.
2、P(n,r) 从n个不同的球中取出r个,放进r个不相同 的盒子中,不许空盒,有多少种放法.
3、 r个相同的球放进n个不同的盒子中,允许 空盒,有多少种放法. 正整数的有序拆分
4 、n个无区别 的球放进r个无区别的盒子,允许空盒。正整数的无序拆分.
书上公式:
n拆分为m个无序的数:
1 m=1或n=1
Q(n,m)= Q(n,n) m>n
1+Q(n,n-1) m=n
Q(n,m-1)+Q(n-m,m)
m个苹果放入n个篮子的更多相关文章
- 将m个苹果放入n个盘子的问题【转】
来自:http://blog.csdn.net/qq675927952/article/details/6312255 问题1: m----->相同, n---> 相同,可为空 将m个苹果 ...
- m个苹果放入n个盘子问题
这个问题,看似是一个简单的排列组合问题,但是加上不同的限制条件,会演变成不同的问题,感觉很奇妙,就总结一下列举下来 问题一 问题描述:把m个同样的苹果放在n个同样的盘子里,允许有的盘子空着不放,问有多 ...
- Rshare Pro是否可以放入至客户企业App Store?
现在很多客户内部部署了苹果授权的企业内部的AppStore,我们的Rshare Pro 是完全允许放入企业搭建的AppStore平台中.但每份需要收费20美元,换成人民币是120元.
- m个相同苹果放的n个相同盘子中的算法
m个相同的苹果,放在n个相同的盘子中,由于相同,使用排列组合的方法不好处理.这个问题困扰了我很久 最后由大神“或缺”给出了答案: 以8个苹果放在3个盘子中为例 思路: 8苹果3盘子 =8苹果2盘子+5 ...
- EC笔记:第三部分:17、使用独立的语句将newed对象放入智能指针
一般的智能指针都是通过一个普通指针来初始化,所以很容易写出以下的代码: #include <iostream> using namespace std; int func1(){ //返回 ...
- tuple放入dict中
tuple放入dict中是否可以正常运行 # 将tuple放入dict中 a = ('AI','Kobe','Yao') b = ('AI',['Kobe','Yao']) dict1 = {'a': ...
- ios-将代码创建的视图控件放入拖拽控件的下面
如图所示 图片是拖拽上去的imageView,橘黄色控件是在代码中创建的添加上去的,此时黄色view在imageView 上方 调用方法bringSubviewToFront:试图将imageView ...
- java通过文件路径读取该路径下的所有文件并将其放入list中
java通过文件路径读取该路径下的所有文件并将其放入list中 java中可以通过递归的方式获取指定路径下的所有文件并将其放入List集合中.假设指定路径为path,目标集合为fileList,遍 ...
- 将DLL放入到资源中,运行时自动加载
今天在看到 一个小软件,考勤用的 AttendanceSheet_V_1_2,只有一个EXE文件,绿色的随便考到哪里都可以运行. 顺手反编译后发现,他将需要的DLL也放入到资源文件了,在启动的时候自动 ...
随机推荐
- powerDesigner生成Html及Word
转载地址:https://blog.csdn.net/zdp072/article/details/51900794 1:点击Reports 2:点击New Reports 3:定义名字,选择简体中文 ...
- MarkDown 使用说明示例
一.标题 一级标题 二级标题 三级标题 四级标题 五级标题 六级标题 一级标题 这是 H2 这是 H3 一级和二级标题还有一种写法 就是下面加横杆,同时 超过2个的 = 和 - 都可以有效果. Thi ...
- 定时任务quartz与spring的集成
我想要在spring的集成框架中使用spring , 暂时采用quartz 根据下面的几篇博客实现了(懒得说了,直接丢链接): Quartz实现动态定时任务 Spring 3整合Quartz 2实现定 ...
- u3d changeTexs
using UnityEngine; using System.Collections; using System.Collections.Generic; public class CTex : M ...
- 移动端控制在input里输入的值只能是数字
<input type='text' oninput="(this.v=function(){this.value=this.value.replace(/[^0-9-]+/,''); ...
- hql Hibernate.gethibernatetemplate()
1. find(String hql); //普通查询 示例:this.gethibernateTemplate().find("from User"); 2. find(Str ...
- 超强OCR文字识别软件首选ABBYY FineReader
提到纸质文档—转换—文本格式—可编辑这些字眼,相信大家的第一反映都是OCR文字识别软件,如何排除错误或利用辅助信息提高识别正确率,是OCR最重要的课题,衡量一个OCR系统性能好坏的主要指标无非是精确度 ...
- CorelDRAW中如何复制对象属性详解
复制对象属性是一种比较特殊.重要的复制方法,它可以方便而快捷地将指定对象中的轮廓笔.轮廓色.填充和文本属性通过复制的方法应用到所选对象中.本教程将详解CorelDRAW中如何复制对象属性. Corel ...
- BarTender软件中GS1-128条码如何制作?
GS1-128条码是UCC/EAN-128条码的新名字,它只是Code 128的一个特殊子集.GS1-128条码是EAN·UCC系统中唯一可用于表示附加信息的条码,可广泛用于非零售贸易项目.物流单元. ...
- CentOS “/lib64/libc.so.6: version `GLIBC_2.14′ not found”系统glibc版本太低
1.试图运行程序提示”libc.so.6: version `GLIBC_2.14′ not found”,原因是系统的glibc版本太低,软件编译时使用了较高版本的glibc引起的.2.查看系统gl ...