既然看到了这道“板子”,那还是来写一下题解吧。。。

如果有机会希望能推一下 载谈binominial sum 的做法。

\[\sum_{k=0}^nf(k)\binom n kx^k(1-x)^{n-k}
\]

看到组合数和多项式求值就去想下降幂吧,因为没什么别的好办法了。。。

设下降幂多项式 \(g(x)=f(x)\)。

\[\sum_{i=0}^m g_i\sum_{k=0}^n\binom n k k^{\underline i} x^k(1-x)^{n-k}
\]

自从联合省选 2020 之后全世界都知道了 \(\binom n m m^{\underline k}=\binom {n-k} {m-k} n^{\underline k}\)。

\[\sum_{i=0}^mg_i\sum_{k=i}^n\binom {n-i} {k-i} n^{\underline i}x^k(1-x)^{n-k}
\]
\[\sum_{i=0}^m g_i n^{\underline i} x^i\sum_{k=0}^{n-i}\binom {n-i} kx^k(1-x)^{n-i-k}
\]

后面根据二项式定理得到是 \(1\)。

\[\sum_{i=0}^m g_i n^{\underline i} x^i
\]

然后把点值乘上 \(e^{-x}\) 就是下降幂多项式了。

  1. #include<cstring>
  2. #include<cstdio>
  3. #include<cctype>
  4. #define IMP(lim,anw) for(i=0;i^(lim);++i)anw
  5. typedef unsigned ui;
  6. const ui M=1e5+5,mod=998244353;
  7. ui buf[M<<2];ui *now=buf,*w[23];
  8. ui n,m,x,f[M],g[M];
  9. inline void swap(ui&a,ui&b){
  10. ui c=a;a=b;b=c;
  11. }
  12. inline ui Add(const ui&a,const ui&b){
  13. return a+b>=mod?a+b-mod:a+b;
  14. }
  15. inline ui Del(const ui&a,const ui&b){
  16. return b>a?a-b+mod:a-b;
  17. }
  18. inline void px(ui*f,ui*g,const ui&len){
  19. for(ui i=0;i^len;++i)f[i]=1ull*f[i]*g[i]%mod;
  20. }
  21. inline ui pow(ui a,ui b=mod-2){
  22. ui ans=1;
  23. for(;b;b>>=1,a=1ull*a*a%mod)if(b&1)ans=1ull*ans*a%mod;
  24. return ans;
  25. }
  26. inline void NTT_init(const ui&m){
  27. ui i,j,n,lim(0);while((1<<lim)<m)++lim;n=1<<lim++;
  28. w[lim]=now;now+=1<<lim-1;
  29. w[lim][0]=1;w[lim][1]=pow(3,(mod-1>>1)/n);
  30. for(i=2;i<(1<<lim-1);++i)w[lim][i]=1ull*w[lim][i-1]*w[lim][1]%mod;
  31. for(j=lim-1;j>=1;--j){
  32. w[j]=now;now+=1<<j;
  33. IMP(1<<j,w[j][i]=w[j+1][i<<1]);
  34. }
  35. }
  36. inline void DFT(ui*f,const ui&n,const ui&M){
  37. ui i,k,d,x,y,*W,*fl,*fr,len;
  38. for(len=n>>1,d=M-1;len^0;len>>=1,--d){
  39. W=w[d];
  40. for(k=0;k^n;k+=len<<1){
  41. fl=f+(k);fr=f+(k|len);
  42. IMP(len,(x=fl[i],y=fr[i])),fl[i]=Add(x,y),fr[i]=1ull*Del(x,y)*W[i]%mod;
  43. }
  44. }
  45. }
  46. inline void IDFT(ui*f,const ui&n,const ui&M){
  47. ui i,k,d,x,y,*W,*fl,*fr,len;
  48. for(len=1,d=1;len^n;len<<=1,++d){
  49. W=w[d];
  50. for(k=0;k^n;k+=len<<1){
  51. fl=f+(k);fr=f+(k|len);
  52. IMP(len,(x=fl[i],y=1ull*fr[i]*W[i]%mod)),fl[i]=Add(x,y),fr[i]=Del(x,y);
  53. }
  54. }
  55. k=pow(n);IMP(n,f[i]=1ull*f[i]*k%mod);
  56. for(i=1;(i<<1)<n;++i)swap(f[i],f[n-i]);
  57. }
  58. signed main(){
  59. ui i,n,a(1),b(1),ans(0),len(0);
  60. scanf("%u%u%u",&n,&m,&x);++m;NTT_init(m<<1);g[0]=1;
  61. for(i=0;i<m;++i)scanf("%u",f+i);while((1<<len)<(m<<1))++len;
  62. for(i=1;i<m;++i)g[i]=1ull*g[i-1]*i%mod;g[m-1]=pow(g[m-1],mod-2);
  63. for(i=m-2;i>=1;--i)g[i]=g[i+1]*(i+1ull)%mod;
  64. for(i=0;i<m;++i)f[i]=1ull*f[i]*g[i]%mod;for(i=1;i<m;i+=2)g[i]=mod-g[i];
  65. DFT(f,1<<len,len+1);DFT(g,1<<len,len+1);px(f,g,1<<len);IDFT(f,1<<len,len+1);
  66. for(i=0;i<m;++i)ans=(ans+1ull*f[i]*a%mod*b)%mod,a=1ull*a*(n-i)%mod,b=1ull*b*x%mod;printf("%u",ans);
  67. }

LGP6667题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

随机推荐

  1. 有关MVC设计模式 #DF

    模型(Model).视图(View).控制器(Controller) -- MVC是 Cocoa 中的一种行为模块,并且也是所有 Cocoa 设计模式中使用最多的.在程序中按照它们的角色来分类这些对象 ...

  2. iOS中JavaScript和OC交互 --by 胡 xu

    在iOS开发中很多时候我们会和UIWebView打交道,目前国内的很多应用都采用了UIWebView的混合编程技术,最常见的是微信公众号的内容页面.前段时间在做微信公众平台相关的开发,发现很多应用场景 ...

  3. 区区牛马蹉跎 ,不要向生活低下头 Linux的账号和管理

    账户和管理权限 1.管理用户账号和组账号 2.管理目录和文件的属性 1.Linux基于用户身份对资源访问进行控制:用户账号(超级用户.普通用户.程序用户) 组账号(基本组.附加组).UID (用户标识 ...

  4. 强化学习中REIINFORCE算法和AC算法在算法理论和实际代码设计中的区别

    背景就不介绍了,REINFORCE算法和AC算法是强化学习中基于策略这类的基础算法,这两个算法的算法描述(伪代码)参见Sutton的reinforcement introduction(2nd). A ...

  5. BumbleBee: 如丝般顺滑构建、交付和运行 eBPF 程序

    本文地址:https://www.ebpf.top/post/bumblebee 1. 前言 不久前,Solo.io 公司在官网博客宣布了开源了一个名称为 BumbleBee 的新项目.该项目专注于简 ...

  6. Kubernetes家族容器小管家Pod在线答疑?

    Kubernetes家族容器小管家Pod在线答疑 不知道学习k8s的小伙伴们有没有跟我一样的疑问? k8s为什么不是直接运行容器,而是让Pod介入? Pod又是什么?为什么在应用容器化如此普遍的情况下 ...

  7. NeurIPS 2017 | QSGD: Communication-Efficient SGD via Gradient Quantization and Encoding

    由于良好的可扩展性,随机梯度下降(SGD)的并行实现是最近研究的热点.实现并行化SGD的关键障碍就是节点间梯度更新时的高带宽开销.因此,研究者们提出了一些启发式的梯度压缩方法,使得节点间只传输压缩后的 ...

  8. CentOS8上安装MySQL

    没有选择Win10上安装MySQL,个人感觉比较傻瓜式.同时相对Win10操作系统,个人更熟悉Unix/Linux操作系统,所以选择在CentOS8上安装MySQL数据库. 还是熟悉的yum安装,前提 ...

  9. 『无为则无心』Python面向对象 — 47、Python中的self详解

    目录 1.self的作用 2.self的使用注意事项 (1)self代表类的实例,而非类 (2)self不必非写成self,只是一种规范. (3)类中方法的形参中一定要写self,包括内置函数 (4) ...

  10. 记一次慢查询优化sql

    sql语句优化(慢查询日志) 最近,旧系统向新系统迁移工程刚刚结束.开发完成后,测试阶段也是好好休息了一把.接到一个需求,由于内部员工使用的网站部分功能加载时间很长,所以需要去优化系统的一些功能.大致 ...