LGP4463题解
这玩意儿怎么看上去就很经典啊(
哦互不相同啊,那没事了(
考虑一个 \(\rm DP\)。由于限制了互不相同,那么我们考虑从值域开始想。
设 \(dp_{n,k}\) 为在 \([1,n]\) 中选了 \(k\) 个数的权值之和。
容易得到有:
\]
很明显考虑 \(0\) 肯定也没有问题。
接下来开始生成函数:
\]
首先这个 \(N-k+1\) 肯定能放到最后去乘上一个阶乘,于是就变成了计算
\]
用 GF 来写的话,因为 \(n\) 的存在,考虑求导:
\]
然后我们有边界条件 \(F_0(x)=1\),答案是 \([x^n]\frac {F_k(x)}{1-x}\)。
注意到 \(F_k(x)\) 一定是类似 \(\frac {G(x)}{(1-x)^y}\) 之类的,所以考虑递推 \(F_k(x)\)。
根据 \(F_k(x)=x(\frac {xF_k(x)}{1-x})'\),我们直接保存 \(F_k(x)=\frac {H(x)}{(1-x)^y}\),然后暴力计算多项式乘法,除法求导利用 \((\frac {F(x)}{G(x)})'=\frac {F'(x)G(x)-F(x)G'(x)}{G^2(x)}\) 即可。
具体来说,计算这个东西:
\]
我们知道 \((F^k(x))'=kF^{k-1}(x)F'(x)\):
\]
\]
答案是类似 \(\frac {F(x)}{(1-x)^{k+1}}\) 的形式,我们又知道 \(\frac 1 {(1-x)^{k+1}}=\sum_{i=0}^{\infty}\binom {i+k}ix^i\),直接卷就好了。
瓶颈在递推,复杂度 \(O(k^2)\)。
别忘记最后要乘上一个阶乘。
#include<cstdio>
typedef unsigned ui;
const ui M=505;
ui n,k,mod,f[M<<1],C[M<<1];
inline ui pow(ui a,ui b){
ui ans(1);for(a%=mod;b;b>>=1,a=1ull*a*a%mod)if(b&1)ans=1ull*ans*a%mod;return ans;
}
signed main(){
ui i,j,inx,ans(0);scanf("%u%u%u",&k,&n,&mod);C[inx=2*n+1>k?k:2*n+1]=f[0]=1;
for(i=1;i<=n;f[1]=f[0],f[0]=0,++i)for(j=i*2;j>=2;--j)f[j]=(1ull*f[j-1]*j+f[j-2]*(2ull*i-j))%mod;
if(inx==2*n+1)for(i=1;i<=2*n;++i)C[inx]=1ull*C[inx]*(k-i)%mod*pow(i,mod-2)%mod;
for(i=inx-1;i<=2*n;--i)C[i]=C[i+1]*(k+2ull*n-i)%mod*pow(k-i,mod-2)%mod;
for(i=0;i<=n*2;++i)ans=(ans+1ull*C[i]*f[i])%mod;for(i=1;i<=n;++i)ans=1ull*ans*i%mod;
printf("%u",ans);
}
LGP4463题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
随机推荐
- cell重用
少数几个cell可不重用 NSString *CellIdentifier = [NSString stringWithFormat:@"MyCellID_%d",indexPat ...
- Annotation深入研究——@Documented注释使用
Documented注释的作用及其javadoc文档生成工具的使用 代码放在MyDocumentedtAnnotationDemo.java文件中 package org.yu.demo16.docu ...
- IP地址与子网划分
IP地址与子网划分 目录 IP地址与子网划分 一.IP地址(Internet Protocol Address) 1.IP地址的表示 2.IP地址的组成 3.IP地址的分类 (1)A类IP地址 (2) ...
- go基础——变量与常量
变量 package main import "fmt" /* 变量:variable 概念:一小块内存,用于存储数据,在程序运行过程中数值可以改变 特性:静态语言,强类型语言 * ...
- requests实现接口测试
python+requests实现接口测试 - get与post请求基本使用方法 http://www.cnblogs.com/nizhihong/p/6567928.html Requests ...
- 第二章 初始MySQL 语法
1.使用MySQL的优势 运行速度快.MySQL体积小,命令执行的速度快: 使用成本低.MySQL是开源的. 容易使用. 可移植性强.MySQL能够运行于多种系统平台之上,windows,linux, ...
- 关于iOS APP转让
需要以下条件即可
- 【笔试必备】常见sql笔试题(30题)
sql是测试从业者必备的技能之一,基本上也是笔试必考内容. 所以,不要让sql拖了后腿,有些测友一遇到多表关联查询就犯晕,甚至连单表的执行顺序都没搞懂,下面简单介绍下,顺便给一些题供大家练习. 单表执 ...
- Wireshark教程之界面介绍
实验目的 1.工具介绍 2.主要应用 实验原理 1.网络管理员用来解决网络问题 2.网络安全工程师用来检测安全隐患 3.开发人员用来测试执行情况 4.学习网络协议 实验内容 1.菜单栏选项介绍 2.快 ...
- 善用商业智能BI系统,让数据分析更智能
数据分析,是一种基于系统化分析问题的方式,是一种手段,也可以是一种工具,可以很简单也可以很复杂.它可以用在各个场景,比如现在的B2C\B2B--等等. 简单点的例子:通过分析购买产品的人大多都来自于北 ...