2019.10.02模拟赛T3
题目大意:
设$S(n,m)$为第二类斯特林数,$F_i$表示斐波那契数列第$i$项。
给定$n,R,K$,求$\sum\limits_{i=1}^{n}(\sum\limits_{m=1}^{R}F_i)!i!\sum\limits_{l=0}^{i}\sum\limits_{j=0}^{\sum\limits_{t=1}^{R}F_t}\frac{S(k,i-l)}{l!}\frac{S(i,\sum\limits_{w=1}^{R}F_w-j)}{j!}$的值$mod$ $1000000007$。
其中$n,R\leq10^{18}$,$k\leq2*10^5$
题解:
(爽感)
这道题...精神污染。。。当然也包括题解的$O(k)$做法。。。
于是我就自己YY了一个$O(klogk)$的能过的做法.
首先,需要知道三个小结论:
1.$\sum\limits_{i=1}^{n}F_i=F_{n+2}-1$,用归纳法可以轻松证明。
2.$m^n=\sum\limits_{i=1}^{m}S(n,i)C_m^ii!$
3.$S(n,m)=\frac{1}{m!}\sum\limits_{i=0}^m(-1)^iC_m^i(m-i)^n$,本质上为结论2经二项式反演后的结果。
证明一下第二个结论:
考虑构造,把$n$个不同的球放入$m$个不同的盒子里,允许有空盒的方案数。
显然,每个球都有$m$种选择方法,答案是$m^n$。
换一种思维方式,可以想成枚举这$n$个球放入了那些盒子里,由于$S(n,m)$表示$n$个不同的球放入$m$个相同的盒子里无空盒的方案数,所以在乘上$C_m^ii!$。
然后就可以开心的化式子了:
设$L=\sum\limits_{m=1}^{R}F_i$,再把原式挪一下就变成了:
$\sum\limits_{i=1}^{n}\sum\limits_{l=0}^{i}i!\frac{S(k,i-l)}{l!}\sum\limits_{j=0}^LL!\frac{S(i,L-j)}{j!}$
然后我们神奇的发现后面的两个式子形式相同,以后一个为例:
$\sum\limits_{j=0}^LL!\frac{S(i,L-j)}{j!}$,换成枚举$L-j$
$=\sum\limits_{j=0}^LL!\frac{S(i,j)}{(L-j)!}$
$=\sum\limits_{j=0}^LS(i,j)C_L^jj!$,这不就是结论2吗,直接等于$L^i$
因此原式直接变为$\sum\limits_{i=0}^nL^ii^k$,但$n$依然很大。
注意当$L=1$时式子变为$\sum\limits_{i=0}^ni^k$,需要用拉格朗日插值法求解,详见CF622F.
若$L\neq1$,我的做法是把$i^k$变回斯特林数,即$\sum\limits_{i=0}^nL^i\sum\limits_{j=0}^kS(k,j)C_i^jj!$
交换求和号,即$\sum\limits_{j=0}^kS(k,j)j!\sum\limits_{i=j}^nC_i^jL^i$,考虑如何快速求出$\sum\limits_{i=j}^nC_i^jL^i$。
设$g(x)=\sum\limits_{i=x}^nC_i^xL^i$
推导一波:
$g(x)=\sum\limits_{i=x}^nL^iC_i^x$
$=\sum\limits_{i=x}^nL^iC_{i-1}^{x-1}+\sum\limits_{i=x}^nL^iC_{i-1}^x$
$=L\sum\limits_{i=x-1}^{n-1}L^{i}C_{i}^{x-1}+L\sum\limits_{i=x}^{n-1}L^{i}C_{i}^x$
$=L(g(x-1)-L^nC_n^{x-1})+L(g(x)-L^nC_n^x)$
在整理一下就是:$g(x)=\frac{Lg(x-1)-L^{n+1}C_{n+1}^x}{1-L}$,那么就可以$O(k)$的复杂度求出$g(x)$
到此为止,原式变为$\sum\limits_{j=1}^kS(k,j)j!g(j)$,问题就剩下如何求第二类斯特林数$S(k,j)$了。
应用第三个结论:$S(n,m)=\frac{1}{m!}\sum\limits_{i=1}^m(-1)^iC_m^i(m-i)^n$,将其化为卷积形式:
$S(n,m)=\sum\limits_{i=1}^m\frac{(-1)^i}{i!}\frac{(m-i)^n}{(m-i)!}$$NTT$即可。
又由于模数不是$NTT$模数,因此需要$MTT$来实现。
#include<cmath>
#include<cstdio>
#include<algorithm>
#define N 530010
#define Re register
#define ld long double
#define mod 1000000007
#define pi (ld)acos(-1)
#pragma GCC optimize(3)
#pragma GCC optimize("inline")
#pragma GCC optimize("Ofast")
using namespace std;
typedef long long ll;
struct node{ll a[][];}tt,an;
int k,R[N];
ll n,r,ans,y[N],S[N],fac[N],inv[N];
node mul(const node&x,const node&y)
{
node ret;
for(Re int i = ;i<=;i++)
{
for(Re int j = ;j<=;j++)
{
ret.a[i][j] = ;
for(Re int k = ;k<=;k++)
ret.a[i][j] = (ret.a[i][j]+x.a[i][k]*y.a[k][j]%mod)%mod;
}
}return ret;
}
inline void mpow(ll y)
{
an.a[][] = an.a[][] = ;
while(y)
{
if(y&)an = mul(an,tt);
tt = mul(tt,tt),y>>=;
}
}
ll ksm(ll x,ll y)
{
ll fin = ;
x%=mod,y%=mod-;
while(y)
{
if(y&)fin = fin*x%mod;
x = x*x%mod,y>>=;
}return fin;
}
struct fs
{
ld x,y;
friend fs operator+(const fs&a,const fs&b){return (fs){a.x+b.x,a.y+b.y};}
friend fs operator-(const fs&a,const fs&b){return (fs){a.x-b.x,a.y-b.y};}
friend fs operator*(const fs&a,const fs&b){return (fs){a.x*b.x-a.y*b.y,a.x*b.y+a.y*b.x};}
}a[N],b[N],c[N],d[N],e[N],f[N],g[N],h[N];
inline void FFT(fs*A,int lim,int fl)
{
for(Re int i = ;i<lim;i++)if(i<R[i])swap(A[i],A[R[i]]);
for(Re int i = ;i<=lim;i<<=)
{
fs wn = (fs){cos(*pi/i),fl*sin(*pi/i)};
for(Re int j = ;j<lim;j+=i)
{
fs w = (fs){,};
for(Re int k = ;k<i>>;k++)
{
fs x = A[j+k],y = w*A[j+k+(i>>)];
A[j+k] = x+y,A[j+k+(i>>)] = x-y;
w = w*wn;
}
}
}if(fl==-)for(Re int i = ;i<lim;i++)A[i].x/=lim;
}
inline void p2()
{
for(Re int i = ;i<=k+;i++)y[i] = (y[i-]+ksm(i,k))%mod;
for(Re int i = ;i<=k+;i++)
{
int t = ;
for(Re int j = ;j<=k+;j++)
{
if(i==j)continue;
t = t*(n%mod-j)%mod*ksm(i-j,mod-)%mod;
}ans = (ans+y[i]*t%mod)%mod;
}printf("%lld",(ans+mod)%mod),exit();
}
int main()
{
freopen("c.in","r",stdin);
freopen("c.out","w",stdout);
scanf("%lld%lld%d",&n,&r,&k);
tt.a[][] = tt.a[][] = tt.a[][] = ;
mpow(r+);
r = an.a[][]-;
if(r==)p2();
fac[] = fac[] = inv[] = inv[] = ;
for(Re int i = ;i<=k;i++)fac[i] = fac[i-]*i%mod,inv[i] = (mod-mod/i)*inv[mod%i]%mod;
for(Re int i = ;i<=k;i++)inv[i] = inv[i]*inv[i-]%mod;
for(Re int i = ;i<=k;i++)
{
ll A = (inv[i]*(i&?-:)+mod)%mod;
ll B = ksm(i,k)*inv[i]%mod;
a[i].x = (ld)(A>>);
b[i].x = (ld)(A&0x7fff);
c[i].x = (ld)(B>>);
d[i].x = (ld)(B&0x7fff);
}
int lim = ,bit = ;
while(lim<=k<<)lim<<=,bit++;
for(Re int i = ;i<lim;i++)R[i] = (R[i>>]>>)|((i&)<<bit-);
FFT(a,lim,),FFT(b,lim,),FFT(c,lim,),FFT(d,lim,);
for(Re int i = ;i<lim;i++)
{
e[i] = a[i]*c[i];
f[i] = a[i]*d[i]+b[i]*c[i];
g[i] = b[i]*d[i];
}
FFT(e,lim,-),FFT(f,lim,-),FFT(g,lim,-);
for(Re int i = ;i<=k;i++)
{
ll E = (ll)round(e[i].x)%mod,F = (ll)round(f[i].x)%mod,G = (ll)round(g[i].x)%mod;
S[i] = (((E<<)%mod+(F<<)%mod+G)%mod+mod)%mod;
}
ll lst = (ksm(r,n+)-)*ksm(r-,mod-)%mod,now = ,t = ksm(r,n+),tt = ksm(-r,mod-);
for(Re int i = ;i<=k;i++)
{
now = now*(n%mod+-i)%mod;
lst = (lst*r%mod-now*inv[i]%mod*t%mod)%mod*tt%mod;
ans = (ans+S[i]*fac[i]%mod*lst%mod)%mod;
}printf("%lld",(ans+mod)%mod);
return ;
}
2019.10.02模拟赛T3的更多相关文章
- 2019.10.18模拟赛T3
题目大意: 求$\sum\limits_{i=1}^n\sum\limits_{j=1}^n[lcm(i,j)>n](n\leq 10^{10})$的值. 题解: 这题貌似有n多种做法... 为 ...
- [10.18模拟赛] 序列 (DP)
[10.18模拟赛] 序列 题目描述 山山有一个整数序列s1,s2,-,sn,其中1≤si≤k. 求出有多少个准确移除m个元素后不同的序列.答案模(1e9+7) 输入 输入包括几个测试用例,并且由文件 ...
- [10.12模拟赛] 老大 (二分/树的直径/树形dp)
[10.12模拟赛] 老大 题目描述 因为 OB 今年拿下 4 块金牌,学校赞助扩建劳模办公室为劳模办公室群,为了体现 OI 的特色,办公室群被设计成了树形(n 个点 n − 1 条边的无向连通图), ...
- EZ 2018 06 10 NOIP2018 模拟赛(十八)
好久没写blog&&比赛题解了,最近补一下 这次还是很狗的,T3想了很久最后竟然连并查集都忘写了,然后T2map莫名爆炸. Rating爆减......链接不解释 好了我们开始看题. ...
- 体育成绩统计——20180801模拟赛T3
体育成绩统计 / Score 题目描述 正所谓“无体育,不清华”.为了更好地督促同学们进行体育锻炼,更加科学地对同学们进行评价,五道口体校的老师们在体育成绩的考核上可谓是煞费苦心.然而每到学期期末时, ...
- 2018.10.17NOIP模拟赛解题报告
心路历程 预计得分:\(100 + 100 +100\) 实际得分:\(100 + 100 + 60\) 辣鸡模拟赛.. 5min切掉T1,看了一下T2 T3,感觉T3会被艹爆因为太原了.. 淦了20 ...
- 20180520模拟赛T3——chess
[问题描述] 小美很喜欢下象棋. 而且她特别喜欢象棋中的马. 她觉得马的跳跃方式很独特.(以日字格的方式跳跃) 小芳给了小美一张很大的棋盘,这个棋盘是一个无穷的笛卡尔坐标. 一开始\(time=0\) ...
- 【2019.10.7 CCF-CSP-2019模拟赛 T3】未知的数组(unknown)(并查集+动态规划)
预处理 考虑模数\(10\)是合数不好做,所以我们可以用一个常用套路: \(\prod_{i=l}^ra_i\equiv x(mod\ 10)\)的方案数等于\(\prod_{i=l}^ra_i\eq ...
- 【2019.8.6 慈溪模拟赛 T3】集合(set)(线段树上DP)
线段树上\(DP\) 首先发现,每个数肯定是向自己的前驱或后继连边的. 则我们开一棵权值线段树,其中每一个节点记录一个\(f_{0/1,0/1}\),表示在这个区间左.右端点是否连过边的情况下,使这个 ...
随机推荐
- Oracle number类型前端界面和数据库查询不一致 number精度问题
[发现问题] [问题分析] Ⅰ.在前端界面查询,发现了库存中存在这样的数量值.但是在数据库中查询时显示正常.即6.999999999999997 为 7. Ⅱ.至于这种小数产生,我以为是oracle存 ...
- mysql 8.0 忘记root密码后重置
最近状态很不好,一直晕晕晕晕晕晕乎乎的,一个测试实例,下班前修改了一下root的密码,接着就下班走人,第二天来发现root密码忘了 刚好自动化安装脚本整理好了,本来想着算了直接重装实例得了,简单省事也 ...
- datatable的dom配置
l - Length changing 改变每页显示多少条数据的控件 f - Filtering input 即时搜索框控件 t - The Table 表格本身 i - Information 表格 ...
- io流追加到一个文件中信息比如日志
package com.yh.day02.arrays; import java.io.File;import java.io.FileInputStream;import java.io.FileN ...
- 关于中医的一段对话 [ZZ] -- 思维训练故事
转载自新浪博客 网址: http://blog.sina.cn/dpool/blog/s/blog_9880df4201015khq.html?type=-1 关于中医的一段对话 2013-01-26 ...
- VMware® Workstation 15 Pro 最新版软件安装教程
VMware 15 Pro下载地址: https://pan.baidu.com/s/1ILY2PTqB-BaJMn2hbKO4CA 提取码:vebd 如有问题咨询QQ:2217084817 VMwa ...
- Leetcode题解 - 树部分简单题目代码+思路(105、106、109、112、897、257、872、226、235、129)
树的题目中递归用的比较多(但是递归是真难弄 我
- Glide生命周期原理
本文首发于 vivo互联网技术 微信公众号 链接:https://mp.weixin.qq.com/s/uTv44vJFFJI_l6b5YKSXYQ作者:连凌能 Android App中图片的展示是很 ...
- Jrebel实现tomcat热部署,遇到的问题以及解决办法,详解
我的安装的详细过程: 下载Jrebel: https://github.com/ilanyu/ReverseProxy/releases/tag/v1.4 我的是winx64,所以选择如下的: 下载 ...
- go语言之range
Go 语言范围(Range) Go 语言中 range 关键字用于 for 循环中迭代数组(array).切片(slice).通道(channel)或集合(map)的元素.在数组和切片中它返回元素的索 ...