题面

传送门

思路

首先,我们发现这个式子中大部分的项都和$j$有关(尤其是后面的$2^j\ast j!$),所以我们更换一下枚举方式,把这道题的枚举方式变成先$j$再$i$

$f(n)=\sum_{j=0}n2j\ast j!\sum_{i=0}nS_ij$

第二类斯特林数有一个基于组合意义的公式:

$S_ij=\frac1{j!}\sum_{k=0}j(-1)kC_jk(j-k)i=\sum_{k=0}j\frac{(-1)k(j-k)i}{k!(j-k)!}$

把这个公式代回原式中,得到:

$f(n)=\sum_{j=0}n2j\ast j!\sum_{i=0}n\sum_{k=0}j\frac{(-1)k(j-k)i}{k!(j-k)!}$

再次更换一下枚举方式,变成:

$f(n)=\sum_{j=0}n2j\ast j!\sum_{k=0}j\frac{(-1)k}{k!}\sum_{i=0}n\frac{(j-k)i}{(j-k)!}$

$f(n)=\sum_{j=0}n2j\ast j!\sum_{k=0}j\frac{(-1)k}{k!}\ast\frac{\sum_{i=0}n(j-k)i}{(j-k)!}$

此时,设两个函数$a$和$b$,令:

$a(i)=\frac{(-1)^i}{i!}$

$b(i)=\frac{\sum_{j=0}nij}{i!}=\frac{i^{n+1}-1}{(i-1)i!}$

那么,

$f(n)=\sum_{j=0}^n 2^j\ast j!\ast(a\ast b)(j)$

其中(a\ast b)(j)表示$a$和$b$的$0-j$项的卷积

模数为$998244353$,用$NTT$做一遍卷积即可,时间效率为$O(nlog_2n)$

注意事项

$b(0)=1,b(1)=n+1$

这两个要提前保存一下,因为用公式推的话会div 0

还有一个奇怪的问题我没有解决,具体看代码最后面吧

Code

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<algorithm>
  5. using namespace std;
  6. inline int read(){
  7. int re=0,flag=1;char ch=getchar();
  8. while(ch>'9'||ch<'0'){
  9. if(ch=='-') flag=-1;
  10. ch=getchar();
  11. }
  12. while(ch>='0'&&ch<='9') re=(re<<1)+(re<<3)+ch-'0',ch=getchar();
  13. return re*flag;
  14. }
  15. #define ll long long
  16. ll MOD=998244353,g=3,inv[400010],f[400010],finv[400010];
  17. int qpow(ll a,ll b){//快速幂
  18. ll re=1;
  19. while(b){
  20. if(b&1) re=re*a%MOD;
  21. a=a*a%MOD;b>>=1;
  22. }
  23. return re;
  24. }
  25. ll n,A[400010],B[400010],C[400010],r[400010],limit,cnt;
  26. void ntt(ll *a,ll type){
  27. int i,j,k,mid;ll y,w,wn;
  28. for(i=0;i<limit;i++) if(i<r[i]) swap(a[i],a[r[i]]);
  29. for(mid=1;mid<limit;mid<<=1){
  30. wn=qpow((type==1)?g:inv[g],(MOD-1)/(mid<<1));
  31. for(j=0;j<limit;j+=(mid<<1)){
  32. w=1;
  33. for(k=0;k<mid;k++,w=w*wn%MOD){
  34. y=a[j+k+mid]*w%MOD;
  35. a[j+k+mid]=(a[j+k]-y+MOD)%MOD;
  36. a[j+k]=(a[j+k]+y)%MOD;
  37. }
  38. }
  39. }
  40. if(type==-1) for(i=0;i<limit;i++) a[i]=a[i]*inv[limit]%MOD;
  41. }
  42. void init(){
  43. limit=1;cnt=0;int i;
  44. while(limit<=(n<<1)) limit<<=1,cnt++;
  45. for(i=0;i<limit;i++) r[i]=((r[i>>1]>>1)|((i&1)<<(cnt-1)));
  46. inv[1]=A[0]=B[0]=f[1]=finv[1]=1;A[1]=MOD-1;B[1]=n+1;
  47. for(i=2;i<=limit;i++) inv[i]=(MOD-MOD/i)*inv[MOD%i]%MOD;
  48. for(i=2;i<=limit;i++){
  49. f[i]=f[i-1]*i%MOD;
  50. finv[i]=finv[i-1]*inv[i]%MOD;
  51. }
  52. }
  53. int main(){
  54. n=read();
  55. init();int i;
  56. for(i=2;i<=n;i++) A[i]=(((i%2)?-1:1)*finv[i]+MOD)%MOD;
  57. for(i=2;i<=n;i++) B[i]=((qpow(i,n+1)-1)*inv[i-1]%MOD*finv[i])%MOD;
  58. ntt(A,1);ntt(B,1);
  59. for(i=0;i<limit;i++) C[i]=A[i]*B[i]%MOD;
  60. ntt(C,-1);
  61. ll ans=0;
  62. for(i=0;i<=n;i++) ans=(ans+qpow(2,i)*f[i]%MOD*C[i]%MOD)%MOD;
  63. printf("%lld\n",(ans+1)%MOD);//这里不知道为什么,一定要加个1,我也没有搞明白
  64. }

[HEOI2016/TJOI2016][bzoj4555] 求和 [斯特林数+NTT]的更多相关文章

  1. 【BZOJ4555】[TJOI&HEOI2016]求和 斯特林数+NTT

    Description 在2016年,佳媛姐姐刚刚学习了第二类斯特林数,非常开心. 现在他想计算这样一个函数的值: S(i, j)表示第二类斯特林数,递推公式为: S(i, j) = j ∗ S(i ...

  2. 【BZOJ】4555: [Tjoi2016&Heoi2016]求和 排列组合+多项式求逆 或 斯特林数+NTT

    [题意]给定n,求Σi=0~nΣj=1~i s(i,j)*2^j*j!,n<=10^5. [算法]生成函数+排列组合+多项式求逆 [题解]参考: [BZOJ4555][Tjoi2016& ...

  3. BZOJ4555 [Tjoi2016&Heoi2016]求和 【第二类斯特林数 + NTT】

    题目 在2016年,佳媛姐姐刚刚学习了第二类斯特林数,非常开心. 现在他想计算这样一个函数的值: S(i, j)表示第二类斯特林数,递推公式为: S(i, j) = j ∗ S(i − 1, j) + ...

  4. 【BZOJ4555】【TJOI2016】【HEOI2016】求和 (第二类斯特林数+NTT卷积)

    Description 在2016年,佳媛姐姐刚刚学习了第二类斯特林数,非常开心. 现在他想计算这样一个函数的值: $$f(n)=\sum_{i=0}^n\sum_{j=0}^i S(i,j)\tim ...

  5. bzoj 4555 [Tjoi2016&Heoi2016] 求和 —— 第二类斯特林数+NTT

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4555 关于第二类斯特林数:https://www.cnblogs.com/Wuweizhen ...

  6. P4091 [HEOI2016/TJOI2016]求和(第二类斯特林数+NTT)

    传送门 首先,因为在\(j>i\)的时候有\(S(i,j)=0\),所以原式可以写成\[Ans=\sum_{i=0}^n\sum_{j=0}^nS(i,j)\times 2^j\times j! ...

  7. BZOJ 4555:[TJOI2016&HEOI2016]求和(第二类斯特林数+NTT)

    题目链接 \(Description\) 求 \[\sum_{i=0}^n\sum_{j=0}^iS(i,j)2^jj!\]对998244353取模后的结果. \(n<=10^5\) \(Sol ...

  8. P4091-[HEOI2016/TJOI2016]求和【斯特林数,NTT】

    正题 题目链接:https://www.luogu.com.cn/problem/P4091 题目大意 给出\(n\),求 \[\sum_{i=0}^n\sum_{j=0}^i\begin{Bmatr ...

  9. 【bzoj5093】 [Lydsy1711月赛]图的价值 组合数+斯特林数+NTT

    Description "简单无向图"是指无重边.无自环的无向图(不一定连通). 一个带标号的图的价值定义为每个点度数的k次方的和. 给定n和k,请计算所有n个点的带标号的简单无向 ...

随机推荐

  1. pandas 常用统计方法

    统计方法 pandas 对象有一些统计方法.它们大部分都属于约简和汇总统计,用于从 Series 中提取单个值,或从 DataFrame 的行或列中提取一个 Series. 比如 DataFrame. ...

  2. 前端异常日志监控 - 使用Sentry

    背景 现在的前端项目越来越复杂,在不同的客户端会产生各种在开发人员机器上不会出现的问题.当用户报告一个问题给开发人员的时候,开发人员无法直接定位问题.在此前,听过一次鹅厂的前端人员,他们对QQ里面的网 ...

  3. CSS清除浮动方法总结

    什么是CSS清除浮动? 在非IE浏览器(如Firefox)下,当容器的高度为auto,且容器的内容中有浮动(float为left或right)的元素,在这种情况下,容器的高度不能自动伸长以适应内容的高 ...

  4. 【搜索】【入门】洛谷P1036 选数

    题目描述 已知 n个整数x1​,x2​,…,xn​,以及1个整数k(k<n).从nn个整数中任选kk个整数相加,可分别得到一系列的和. 例如当n=4,k=3,4个整数分别为3,7,12,19时, ...

  5. 题解 P3367 【【模板】并查集】

    #include<iostream> #include<cstdio> using namespace std; int n,m,x,y,z; ]; //f[i]表示i的祖先 ...

  6. mysql 报错 Operand should contain 1 column(s)

    报错 Operand should contain 1 column(s) 原因 select 后面加了 () select (x,x,x)

  7. 14.2-ELK 经典用法—企业自定义日志收集切割和mysql模块

    本文收录在Linux运维企业架构实战系列 一.收集切割公司自定义的日志 很多公司的日志并不是和服务默认的日志格式一致,因此,就需要我们来进行切割了. 1.需切割的日志示例 2018-02-24 11: ...

  8. 无线Web开发

    http://am-team.github.io/amg/dev-exp-doc.html

  9. Python知识点进阶——细节问题

    int()强制转换浮点数 在int()的强制转换浮点数时候,不管是正数还是负数,只取整数部分. 注意:这里不是向上或者向下取整,也不是四舍五入. 无限递归 递归是为了将问题简化为更小规模的同类型问题, ...

  10. Android中级教程之Android应用程序的生命周期

    Android应用程序的生命周期图 在大部分情况下,每个Android应用都将运行在自己的Linux进程中.当这个应用的某些代码需要执行时,进程就会被创建,并且将保持运行,直到该进程不再需要,而系统需 ...