Partition HDU - 4602 (不知道为什么被放在了FFT的题单里)
题目链接:Vjudge 传送门
相当于把nnn个点分隔为若干块,求所有方案中大小为kkk的块数量
我们把大小为kkk的块,即使在同一种分隔方案中的块
单独考虑,它可能出现的位置是在nnn个点的首、尾、中
- 出现在首尾时,有222种情况,此时剩下的点有(n−k−1)(n-k-1)(n−k−1)个间隔,每个间隔可分可不分,所以方案数为2⋅2(n−k−1)2\cdot 2^{(n-k-1)}2⋅2(n−k−1)
- 出现在中间时,有(n−k−1)(n-k-1)(n−k−1)种情况,此时剩下的点有(n−k−2)(n-k-2)(n−k−2)个间隔,每个间隔可分可不分,所以方案数为(n−k−1)⋅2(n−k−2)(n-k-1)\cdot 2^{(n-k-2)}(n−k−1)⋅2(n−k−2)
加起来即为(n−k+1)⋅2(n−k−2)(n-k+1)\cdot2^{(n-k-2)}(n−k+1)⋅2(n−k−2)
注意此处要特判3种情况
(1)n<k
(2)n=k
(3)n-k-2=-1
n−k−2n-k-2n−k−2若更小,如为−2-2−2,则nnn已经等于kkk了
AC code
#include <cstdio>
typedef long long LL;
const int mod = 1e9 + 7;
inline int qmul(int a, int b)
{
	int ret = 1;
	while(b)
	{
		if(b & 1) ret = (LL)ret * a % mod;
		a = (LL)a * a % mod; b >>= 1;
	}
	return ret;
}
int main ()
{
	int T, n, k;
	scanf("%d", &T);
	while(T--)
	{
		scanf("%d%d", &n, &k);
		if(n < k) puts("0");
		else if(n == k) puts("1");
		else if(n == k+1) puts("2");
		else
		{
			printf("%lld\n", (LL)(n-k+3) * qmul(2, n-k-2) % mod);
		}
	}
}
Partition HDU - 4602 (不知道为什么被放在了FFT的题单里)的更多相关文章
- hdu 5288||2015多校联合第一场1001题
		pid=5288">http://acm.hdu.edu.cn/showproblem.php?pid=5288 Problem Description OO has got a ar ... 
- CSP-J2019 把8个同样的球放在同样的5个袋子里,允许有的袋子空着不放,问共有多少种不同的分法?
		把8个同样的球放在同样的5个袋子里,允许有的袋子空着不放,问共有多少种不同的分法? 提示:如果8个球都放在一个袋子里,无论是放哪个袋子,都只算同一种分法. 解析: 把问题合成,先思索5个袋子都不空的状 ... 
- hdu 4602 Partition
		http://acm.hdu.edu.cn/showproblem.php?pid=4602 输入 n 和 k 首先 f(n)中k的个数 等于 f(n-1) 中 k-1的个数 最终等于 f(n-k+1 ... 
- hdu 4602 Partition 数学(组合-隔板法)
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4602 我们可以特判出n<= k的情况. 对于1<= k<n,我们可以等效为n个点排成 ... 
- hdu 4602 Partition (概率方法)
		Partition Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ... 
- HDU  4602  Partition (矩阵乘法)
		Partition Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ... 
- hdu 4602 Partition  矩阵快速幂
		Partition Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Proble ... 
- 【HDU 4602】Partition
		题意 给你一个数n,把它写成几个正整数相加的形式,即把n拆开成若干段,把所有可能的式子里正整数 k 出现的次数取模是多少. 分析 特判 k>=n 的情况. k<n时:问题相当于n个点排一行 ... 
- hdu 4602 Partition(快速幂)
		推公式+快速幂 公式有很多形式,可以写矩阵 1.前n-1项和的两倍+2的(n-2)次方,这个写不出啥 2.递推式:f(n)=2*f(n-1)+2的(n-3)次方 3.公式:2的(n-k-2)次方*(n ... 
随机推荐
- [转帖]70亿!以色列间谍产品公司NSO要被卖掉了
			70亿!以色列间谍产品公司NSO要被卖掉了 2017-06-14 11:11 https://www.sohu.com/a/148739327_257305 E安全6月14日讯以色列的网络能力处于世界 ... 
- 工厂方法(FactoryMethod)模式
			之前说了简单工厂设计模式如果增加一个新的运算的时候需要:增加一个具体的实现类,工厂类中增加一个case分支.也就是说我们不但对扩展开发了,也对修改开放了,违背了开闭原则.当然如果工厂类采用反射的话不存 ... 
- C++ 工程师养成 每日一题third (子数列排序)
			题目: 定义排序子序列为一个数组中一段连续的子序列,并且这段子序列是非递增或者非递减排序的.牛牛有一个长度为n的整数数组A,他现在有一个任务是把数组A分为若干段排序子序列,牛牛想知道他最少可以把这个数 ... 
- Python学习之路:函数传递可变参数与不可变参数
			函数传参的方法: 太基础了,8说了 直接上重点 一.可变参数的传递 可变参数有:列表.集合.字典 直接上代码: a = [1, 2] def fun(a): print('传入函数时a的值为:', a ... 
- threading.local和高级
			threading.local特点 ①为每个线程开辟空间,让你进行存取值(根据线程ID来固定某个值) ②flask中没有threading.local,但是flask中的上下文管理的思想是借鉴的thr ... 
- 2019-7-16  import / from...import...   模块的调用
			模块调用的总结:如果你是pycharm打开文件,会自动帮你把文件根目录加到system.path中,你要调用模块直接以根目录为基准开始找.1.假如你要调用和文件根目录为同级的文件,你直接import ... 
- go 指针 通过指针修改int类型的值
			指针的定义 :var p *int 取指针的值 :*p ------------------------------------------------------------------------ ... 
- 玩机之HUAWEI_Nova
			Nova是一款挺早的机型了.最开始使用华为就觉得这一款最好挺好用,屏幕小巧功能强大.当然也离不开手机,最早的TWRP就是在此机型上初步尝试成功,也算学习,那时候还没有玩过.这部手机算是改机最完美的一部 ... 
- pytest_05_fixture之conftest.py
			前面一篇讲到用例加setup和teardown可以实现在测试用例之前或之后加入一些操作,但这种是整个脚本全局生效的,如果我想实现以下场景: 用例1需要先登录,用例2不需要登录,用例3需要先登录.很显然 ... 
- Go ---- defer 和 return 执行的先后顺序
			Go 中 defer 和 return 执行的先后顺序 多个defer的执行顺序为“后进先出”: defer.return.返回值三者的执行逻辑应该是:return最先执行,return负责将结果写入 ... 
