[递推]C. 【例题3】数的划分
C
.
【
例
题
3
】
数
的
划
分
C. 【例题3】数的划分
C.【例题3】数的划分
题目描述
将整数
n
n
n 分成
k
k
k 份,且每份不能为空,任意两个方案不相同(不考虑顺序)。
例如:
n
=
7
n=7
n=7,
k
=
3
k=3
k=3,下面三种分法被认为是相同的:
1
,
1
,
5
;
1
,
5
,
1
;
1
,
1
,
5.
1,1,5;~~~~1,5,1;~~~~1,1,5.
1,1,5; 1,5,1; 1,1,5.
问有多少种不同的分法。
输入格式
两个整数,
n
n
n和
k
k
k 。
输出格式
输出不同的分法数。
样例
输入样例
7
3
7 ~~~3
7 3
输出样例
4
4
4
样例说明
四种分法为:
1
,
1
,
5
;
1
,
2
,
4
;
1
,
3
,
3
;
2
,
2
,
3.
1,1,5;~~~~ 1,2,4; ~~~~1,3,3;~~~~ 2,2,3.
1,1,5; 1,2,4; 1,3,3; 2,2,3.
题目解析
看题面,首先想到递推.
设
t
(
n
,
k
)
为
t(n,k)为
t(n,k)为整数
n
n
n分为
k
k
k份的不同分法的数量.
因为不能为空,那么最小就只能分到
1
1
1.
那么我们就可以得出:
t
(
n
,
k
)
=
1
(
n
=
=
k
)
t(n,k)=1~~~(n==k)~~~~~~~~~~~~
t(n,k)=1 (n==k) (因为每份最多都是
1
1
1)
t
(
n
,
k
)
=
0
(
n
<
k
)
t(n,k)=0~~~(n<k)~~~~~~~~~~~~~~~
t(n,k)=0 (n<k) (因为就算每份都只放
1
1
1也不够放,而且都不能为空)
然后我们考虑两种情况
- 有一份是装有
1
1
1的:那么就有
t
(
n
−
1
,
k
−
1
)
t(n-1,k-1)
t(n−1,k−1)种情况
- 没有一份是装有
1
1
1的:那么就有
t
(
n
−
k
,
k
)
t(n-k,k)
t(n−k,k)种情况
那么就能得出递推式:
t
(
n
,
k
)
=
{
t
(
n
,
k
)
=
1
(
n
=
=
k
)
t
(
n
,
k
)
=
0
(
n
<
k
)
t
(
n
,
k
)
=
t
(
n
−
1
,
k
−
1
)
+
t
(
n
−
k
,
k
)
t(n,k) = \left\{\begin{matrix} & t(n,k)=1~~~~~~~~~~~~~(n==k)\\ & t(n,k)=0~~~~~~~~~~~~~~~~(n<k)\\ & t(n,k)=t(n-1,k-1)+t(n-k,k)\\ \end{matrix}\right.
t(n,k)=⎩⎨⎧t(n,k)=1 (n==k)t(n,k)=0 (n<k)t(n,k)=t(n−1,k−1)+t(n−k,k)
Code
#include <bits/stdc++.h>
using namespace std;
int n, k, t[205][10];
int main ()
{
scanf ("%d%d", &n, &k);
memset (t, 0, sizeof (t));
for (int i = 1; i <= n; ++ i)
{
for (int j = 1; j <= k; ++ j)
{
if (i == j) t[i][j] = 1; //每个都分1
else if (i < j) t[i][j] = 0; //每个都分1也不够
else t[i][j] = t[i - 1][j - 1]/*至少有一个份为1的方案数*/ + t[i - j][j]/*当没有任何一份为1时的方案数*/;
}
}
printf ("%d", t[n][k]);
return 0;
}
[递推]C. 【例题3】数的划分的更多相关文章
- 【递推】【卡特兰数】CODEVS 3134 Circle
新GET了一种卡特兰数的应用…… 在一个圆上,有2*K个不同的结点,我们以这些点为端点,连K条线段,使得每个结点都恰好用一次.在满足这些线段将圆分成最少部分的前提下,请计算有多少种连线的方法. 不会证 ...
- LightOJ - 1038 Race to 1 Again 递推+期望
题目大意:给出一个数,要求你按一定的规则将这个数变成1 规则例如以下,如果该数为D,要求你在[1,D]之间选出D的因子.用D除上这个因子,然后继续按该规则运算.直到该数变成1 问变成1的期望步数是多少 ...
- 大概是:整数划分||DP||母函数||递推
整数划分问题 整数划分是一个经典的问题. Input 每组输入是两个整数n和k.(1 <= n <= 50, 1 <= k <= n) Output 对于每组输入,请输出六行. ...
- [luogu]P1066 2^k进制数[数学][递推][高精度]
[luogu]P1066 2^k进制数 题目描述 设r是个2^k 进制数,并满足以下条件: (1)r至少是个2位的2^k 进制数. (2)作为2^k 进制数,除最后一位外,r的每一位严格小于它右边相邻 ...
- [递推]D. 【例题4】传球游戏
D . [ 例 题 4 ] 传 球 游 戏 D. [例题4]传球游戏 D.[例题4]传球游戏 题目解析 设 t ( i , j ) t(i,j) t(i,j)为过了 j j j轮,轮到 i i i手上 ...
- BZOJ-1002 轮状病毒 高精度加减+Kirchhoff矩阵数定理+递推
1002: [FJOI2007]轮状病毒 Time Limit: 1 Sec Memory Limit: 162 MB Submit: 3543 Solved: 1953 [Submit][Statu ...
- 【递推】BZOJ 3930: [CQOI2015]选数
Description 我们知道,从区间[L,H](L和H为整数)中选取N个整数,总共有(H-L+1)^N种方案.小z很好奇这样选出的数的最大公约数的规律,他决定对每种方案选出的N个整数都求一次最大公 ...
- CODE[VS]-数的计算-递推-天梯白银
题目描述 Description 我们要求找出具有下列性质数的个数(包含输入的自然数n): 先输入一个自然数n(n<=1000),然后对此自然数按照如下方法进行处理: 1.不作任何处理; 2.在 ...
- 洛谷 P1028 数的计算【递推】
P1028 数的计算 题目描述 我们要求找出具有下列性质数的个数(包含输入的自然数n): 先输入一个自然数n(n<=1000),然后对此自然数按照如下方法进行处理: 1.不作任何处理; 2.在它 ...
随机推荐
- Nodejs 使用 TypeScript
安装依赖 λ yarn add typescript types/node concurrently nodemon wait-on -D 初始化一个 tsconfig.json λ ./node_m ...
- ajax缺点
ajax请求在SEO中效率低,SEO就是关键字搜索的匹配度. 比如在百度搜索Java,一般来说内容中出现Java的次数越多排名越靠前,当使用ajax时,它的异步刷新导致必须是页面刷新出来才去刷新数据, ...
- tep环境变量、fixtures、用例三者之间的关系
tep是一款测试工具,在pytest测试框架基础上集成了第三方包,提供项目脚手架,帮助以写Python代码方式,快速实现自动化项目落地. 在tep项目中,自动化测试用例都是放到tests目录下的,每个 ...
- redis.conf 配置说明
redis.conf 配置项说明如下: 1. Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程 daemonize no 2. 当Redis以守护进程方式运行时,R ...
- MySQL注入 前端int型参数插入SQL语句
类似PHP语言的 mysql_real_escape_string() 的函数,在用来防范SQL注入的时候,可能会遇到int型注入成功的情况. mysql_real_escape_string()用法 ...
- macOS下Chrome和Safari导入证实抓包HTTPS
目录 下载证书 mac OS导入证书 Chrome设置代理 Safari设置代理 下面的操作基于Mac OS Catalina(v10.15.3),抓包拦截工具基于Burp Suite v2.1.05 ...
- 一个页面中多个window.onload = function(){}冲突问题解决思路
转: 一个页面中多个window.onload = function(){}冲突问题解决思路 一个页面中多个window.onload = function(){}冲突问题解决思路 参考文章: (1) ...
- c++ string类使用及用string类解决整行字符串输入
下面随笔给出c++ string类使用及用string类解决整行字符串输入. string类 使用字符串类string表示字符串 string实际上是对字符数组操作的封装 string类常用的构造函数 ...
- WebService和Web API 区别
WebService的特征: 1 基于SOAP协议的,数据格式为XML 2 只支持HTTP协议,只能部署在IIS上 3 不是开源的,但可以被任意一个了解XML的人使用 SOAP :简单对象访问协议Si ...
- JavaScript数组的几个常用的API
一. 扁平化嵌套数组/展平和阵列孔--flat() 1.实现效果 var arr1 = [1, 2, [3, 4]]; arr1.flat(); // [1, 2, 3, 4] var arr2 = ...