【TJOI/HEOI2016】求和

这题好难啊!!

斯特林数+NTT。

首先我们将第二类斯特林数用容斥展开,具体原理不解释了。

\(\displaystyle S(i,j)=\frac{1}{j!}\sum_{k=0}^{j}(-1)^{k}C_j^k(j-k)^i=\sum_{k=0}^{j}\frac{(-1)^k}{k!}\cdot\frac{(j-k)^i}{(j-k)!}\)。

我们交换一下\(\sum\)的顺序:

\(\displaystyle f(n)=\sum_{j=0}^{n}2^jj!\sum_{i=0}^{n}S(i,j)\)。这里\(i\)从0开始枚举是没有问题的,因为\(j>i时,S(i,j)=0\)。

将斯特林数展开:

\[\displaystyle f(n)=\sum_{j=0}^{n}2^jj!\sum_{i=0}^{n}\sum_{k=0}^j\frac{(-1)^k}{k!}\cdot\frac{(j-k)^i}{(j-k)!}\\
=\sum_{j=0}^{n}2^jj!\sum_{k=0}^j\frac{(-1)^k}{k!}\sum_{i=0}^n\frac{(j-k)^i}{(j-k)!}
\]

很容易看出,最后一个\(\sum\)是一个等比数列求和。

于是我们设\(g(i)=\frac{i^{n+1}-1}{(i-1)*i!},特别地,g(0)=1,g(1)=n+1\)。

于是\(\displaystyle f(n)=\sum_{j=0}^{n}2^jj!\sum_{k=0}^j\frac{(-1)^k}{k!}g(j-k)\)

我们又设\(h(i)=\frac{(-1)^i}{i!}\),则\(\displaystyle f(n)=\sum_{j=0}^{n}2^jj!\sum_{k=0}^jh(k)g(j-k)\)

\(\displaystyle \sum_{k=0}^jh(k)g(j-k)\)是个卷积,可以用NTT来计算。

代码:

  1. #include<bits/stdc++.h>
  2. #define ll long long
  3. #define mod 998244353
  4. #define N 200005
  5. using namespace std;
  6. inline int Get() {int x=0,f=1;char ch=getchar();while(ch<'0'||ch>'9') {if(ch=='-') f=-1;ch=getchar();}while('0'<=ch&&ch<='9') {x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}return x*f;}
  7. int n;
  8. ll fac[N],inv[N];
  9. ll ksm(ll t,ll x) {
  10. ll ans=1;
  11. for(;x;x>>=1,t=t*t%mod)
  12. if(x&1) ans=ans*t%mod;
  13. return ans;
  14. }
  15. ll a[N<<2],b[N<<2],q[N];
  16. const ll g=3;
  17. ll tem[N<<2];
  18. int rev(int x,int len) {
  19. int ans=0;
  20. for(;len;len--,x>>=1) ans=ans<<1|x&1;
  21. return ans;
  22. }
  23. void NTT(ll *a,int x,int flag) {
  24. int n=1<<x;
  25. for(int i=0;i<n;i++) if(i<rev(i,x)) swap(a[i],a[rev(i,x)]);
  26. tem[0]=1;
  27. for(int s=1;s<=x;s++) {
  28. int len=1<<s,mid=len>>1;
  29. ll w=flag==1?ksm(g,(mod-1)/len):ksm(g,mod-1-(mod-1)/len);
  30. for(int i=1;i<mid;i++) tem[i]=tem[i-1]*w%mod;
  31. for(int i=0;i<n;i+=len) {
  32. for(int j=0;j<mid;j++) {
  33. ll u=a[i+j];
  34. ll v=tem[j]*a[i+j+mid]%mod;
  35. a[i+j]=(u+v)%mod;
  36. a[i+j+mid]=(u-v+mod)%mod;
  37. }
  38. }
  39. }
  40. if(flag==-1) {
  41. ll inv=ksm(n,mod-2);
  42. for(int i=0;i<n;i++) a[i]=a[i]*inv%mod;
  43. }
  44. }
  45. int bl[1000];
  46. int main() {
  47. n=Get();
  48. fac[0]=1;
  49. for(int i=1;i<=n;i++) fac[i]=fac[i-1]*i%mod;
  50. inv[n]=ksm(fac[n],mod-2);
  51. for(int i=n-1;i>=0;i--) inv[i]=inv[i+1]*(i+1)%mod;
  52. int flag=1;
  53. for(int i=0;i<=n;i++,flag*=-1) {
  54. if(flag==1) a[i]=inv[i];
  55. else a[i]=(mod-inv[i])%mod;
  56. }
  57. q[0]=1;
  58. q[1]=n+1;
  59. for(int i=2;i<=n;i++) {
  60. q[i]=((ksm(i,n+1)-1)*ksm(i-1,mod-2)%mod+mod)%mod;
  61. }
  62. for(int i=0;i<=n;i++) b[i]=q[i]*inv[i]%mod;
  63. int x=0;
  64. for(int len=n<<2;len;len>>=1,x++);
  65. NTT(a,x,1),NTT(b,x,1);
  66. for(int i=0;i<(1<<x);i++) a[i]=a[i]*b[i]%mod;
  67. NTT(a,x,-1);
  68. ll ans=0;
  69. ll p=1;
  70. for(int i=0;i<=n;i++) {
  71. (ans+=p*fac[i]%mod*a[i]%mod)%=mod;
  72. p=(p<<1)%mod;
  73. }
  74. cout<<ans;
  75. return 0;
  76. }

【TJOJI\HEOI2016】求和的更多相关文章

  1. BZOJ 4555: [Tjoi2016&Heoi2016]求和 [分治FFT 组合计数 | 多项式求逆]

    4555: [Tjoi2016&Heoi2016]求和 题意:求\[ \sum_{i=0}^n \sum_{j=0}^i S(i,j)\cdot 2^j\cdot j! \\ S是第二类斯特林 ...

  2. BZOJ 4555: [Tjoi2016&Heoi2016]求和 [FFT 组合计数 容斥原理]

    4555: [Tjoi2016&Heoi2016]求和 题意:求\[ \sum_{i=0}^n \sum_{j=0}^i S(i,j)\cdot 2^j\cdot j! \\ S是第二类斯特林 ...

  3. [HEOI2016]求和 sum

    [HEOI2016]求和 sum 标签: NTT cdq分治 多项式求逆 第二类斯特林数 Description 求\[\sum_{i=0}^n\sum_{j=0}^i S(i,j)×2^j×(j!) ...

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

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

  5. 【BZOJ 4555】 4555: [Tjoi2016&Heoi2016]求和 (NTT)

    4555: [Tjoi2016&Heoi2016]求和 Time Limit: 40 Sec  Memory Limit: 128 MBSubmit: 315  Solved: 252 Des ...

  6. [BZOJ4555][TJOI2016&HEOI2016]求和(分治FFT)

    4555: [Tjoi2016&Heoi2016]求和 Time Limit: 40 Sec  Memory Limit: 128 MBSubmit: 525  Solved: 418[Sub ...

  7. bzoj 4555 [Tjoi2016&Heoi2016]求和 NTT 第二类斯特林数 等比数列求和优化

    [Tjoi2016&Heoi2016]求和 Time Limit: 40 Sec  Memory Limit: 128 MBSubmit: 679  Solved: 534[Submit][S ...

  8. [BZOJ4555 TJOI2016 HEOI2016 求和]

    ​ 第一篇博客,请大家多多关照.(鞠躬 BZOJ4555 TJOI2016 HEOI2016 求和 题意: ​ 给定一个正整数\(n\)(\(1\leqq n \leqq100000\)),求: \[ ...

  9. [TJOI2016&&HEOI2016]求和

    BZOJ Luogu 求 \[f(n)=\sum_{i=0}^{n}\sum_{j=0}^{i}S(i,j)*2^j*j!\] 其中\(S(i,j)\)是第二类斯特林数 \(n\le10^5\),模\ ...

随机推荐

  1. sql 表连接

     join (inner join ) 注释:INNER JOIN 关键字在表中存在至少一个匹配时返回行. left join  注释:LEFT JOIN 关键字从左表(table1)返回所有的行,即 ...

  2. php递归操作目录 递归对参数转义

    header("Content-type:text/html;charset=utf-8"); //递归读取目录 function reddir($path,$level=0) { ...

  3. Vue2.5开发去哪儿网App 详情页面开发

    一,banner 图的设计 1. 新建detail的路由 import Detail from '@/pages/detail/Detail' ...... { path: '/detail', na ...

  4. 记一次升级Tomcat

    总述     JDK都要出12了,而我们项目使用的jdk却仍然还停留在JDK1.6.为了追寻技术的发展的脚步,我这边准备将项目升级到JDK1.8.而作为一个web项目,我们的容器使用的是Tomcat. ...

  5. 自定义滚动条mCustomScrollbar

    mCustomScrollbar 是个基于 jQuery UI 的自定义滚动条插件,它可以让你灵活的通过 CSS 定义网页的滚动条,并且垂直和水平两个方向的滚动条都可以定义,它通过 Brandon A ...

  6. Java,第16天,属性与方法;

    public class 类名{ private double 财产 = 0://设一个财产的属性: public void 一个月工资(){ this.财产 +=4500: }//设一个方法增加财产 ...

  7. iphone 上微信的“复制链接”功能复制出来的是修改前的链接

    问题描述: 在 iOS 系统中,用微信打开了 A 页面的链接,然后由 A 页面进入 B 页面 在 B 页面打开微信右上角菜单,使用“复制链接”功能 最后粘贴出来的链接是 A 页面的链接 分析原因: 这 ...

  8. CSS常见布局

    一.单列布局 1. 水平居中 1.1 使用inline-block和text-align .parent{text-align:center;} .child{display:inline-block ...

  9. 2017-11-20 中文代码示例之Vuejs入门教程(一)问题后续

    "中文编程"知乎专栏原文 第一个issue: Error compiling template if using unicode naming as v-for alias · I ...

  10. docker 安装软件

    Docker Docker官方网址: https://docs.docker.com/  英文地址 Docker中文网址: http://www.docker.org.cn/ 中文地址 Docker是 ...