Peter算法小课堂—球盒问题

球盒问题有8类,分别如下图

相同的球放入相同的盒子

根据上一篇Peter算法小课堂---正整数拆分-CSDN博客

简单来说,就这样👇

将相同的球放入相同的盒子,其实相当于将正整数i分为j个正整数的个数

cpp 复制代码
cin>>n>>m;
if(n<m){
	cout<<0<<endl;
	return 0;
}
for(ll i=2;i<=n;i++) f[i][1]=1;
for(ll j=2;j<=m;j++)
	for(ll i=j;i<=n;i++)
		f[i][j]=f[i-1][j-1]+f[i-j][j];
cout<<f[n][n]<<endl;

相同的球放入不同的盒子

其实,我们直接排列组合一下

以每个盒子至少一个球举例。我们将这些球排成一排,用一些板把它们分开。如下图

若每个盒子可为空,则我们可以在每个盒子里提前放一个球,其它同上。

cpp 复制代码
cin>>n>>m;
if(n<m){
	cout<<0<<endl;
	return 0;
}
ll ans=1;
for(ll i=1;i<=m-1;i++){
	ans*=n-i;
	ans/=i;
}
cout<<ans<<endl;

不同的球放入相同的盒子(第二类stirling数)

fij表示将前i个球放入相同的盒子,不允许空的情况,具体状态转移方程请看下图

第一种情况,左边:选完后变成m-1个装n-1个球,fn-1m-1

第二种情况,右边:先让前n-1个球放m盒子,第n个球挑一盒

cpp 复制代码
cin>>n>>m;
if(n<m){
	cout<<0<<endl;
	return 0;
}
for(ll i=1;i<=n;i++) S[i][1]=1;
for(ll j=2;j<=m;j++)
	for(ll i=j;i<=n;i++)
		S[i][j]=S[i-1][j-1]+j*S[i-1][j];
cout<S[n][m]<<endl;

不同的球放入不同的盒子

假设球相同,那么答案就是Snm

然后再排列球,m!

因此,答案就是Snm*m!

希望这些对大家有用,谢谢😀

相关推荐
8Qi86 小时前
回文子串(Palindromic Substrings)—— 题解
算法·leetcode·职场和发展·动态规划
wabs6661 天前
关于动态规划【力扣343.整数拆分的递推公式怎么理解?】
算法·leetcode·动态规划
珊瑚里的鱼1 天前
【动态规划】买卖股票的最佳时机含手续费
算法·动态规划
随意起个昵称1 天前
线性dp-LIS题目6(友好城市,二分优化)
算法·动态规划
8Qi82 天前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
wabs6662 天前
关于动态规划【力扣63.不同路径II与62.不同路径的区别(C++)】自我总结
动态规划
三千里2 天前
路径规划算法-备忘
算法·自动驾驶·动态规划
2601_961845152 天前
新高考一卷真题2025|真题PDF全科整理
线性代数·矩阵·pdf·动态规划·概率论·高考
随意起个昵称2 天前
线性dp-LIS题目5(导弹拦截,二分优化)
c++·算法·动态规划
8Qi82 天前
LeetCode 5:最长回文子串(Longest Palindromic Substring)—— 题解
算法·leetcode·职场和发展·动态规划