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

如果有机会希望能推一下 载谈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}\) 就是下降幂多项式了。

#include<cstring>
#include<cstdio>
#include<cctype>
#define IMP(lim,anw) for(i=0;i^(lim);++i)anw
typedef unsigned ui;
const ui M=1e5+5,mod=998244353;
ui buf[M<<2];ui *now=buf,*w[23];
ui n,m,x,f[M],g[M];
inline void swap(ui&a,ui&b){
ui c=a;a=b;b=c;
}
inline ui Add(const ui&a,const ui&b){
return a+b>=mod?a+b-mod:a+b;
}
inline ui Del(const ui&a,const ui&b){
return b>a?a-b+mod:a-b;
}
inline void px(ui*f,ui*g,const ui&len){
for(ui i=0;i^len;++i)f[i]=1ull*f[i]*g[i]%mod;
}
inline ui pow(ui a,ui b=mod-2){
ui ans=1;
for(;b;b>>=1,a=1ull*a*a%mod)if(b&1)ans=1ull*ans*a%mod;
return ans;
}
inline void NTT_init(const ui&m){
ui i,j,n,lim(0);while((1<<lim)<m)++lim;n=1<<lim++;
w[lim]=now;now+=1<<lim-1;
w[lim][0]=1;w[lim][1]=pow(3,(mod-1>>1)/n);
for(i=2;i<(1<<lim-1);++i)w[lim][i]=1ull*w[lim][i-1]*w[lim][1]%mod;
for(j=lim-1;j>=1;--j){
w[j]=now;now+=1<<j;
IMP(1<<j,w[j][i]=w[j+1][i<<1]);
}
}
inline void DFT(ui*f,const ui&n,const ui&M){
ui i,k,d,x,y,*W,*fl,*fr,len;
for(len=n>>1,d=M-1;len^0;len>>=1,--d){
W=w[d];
for(k=0;k^n;k+=len<<1){
fl=f+(k);fr=f+(k|len);
IMP(len,(x=fl[i],y=fr[i])),fl[i]=Add(x,y),fr[i]=1ull*Del(x,y)*W[i]%mod;
}
}
}
inline void IDFT(ui*f,const ui&n,const ui&M){
ui i,k,d,x,y,*W,*fl,*fr,len;
for(len=1,d=1;len^n;len<<=1,++d){
W=w[d];
for(k=0;k^n;k+=len<<1){
fl=f+(k);fr=f+(k|len);
IMP(len,(x=fl[i],y=1ull*fr[i]*W[i]%mod)),fl[i]=Add(x,y),fr[i]=Del(x,y);
}
}
k=pow(n);IMP(n,f[i]=1ull*f[i]*k%mod);
for(i=1;(i<<1)<n;++i)swap(f[i],f[n-i]);
}
signed main(){
ui i,n,a(1),b(1),ans(0),len(0);
scanf("%u%u%u",&n,&m,&x);++m;NTT_init(m<<1);g[0]=1;
for(i=0;i<m;++i)scanf("%u",f+i);while((1<<len)<(m<<1))++len;
for(i=1;i<m;++i)g[i]=1ull*g[i-1]*i%mod;g[m-1]=pow(g[m-1],mod-2);
for(i=m-2;i>=1;--i)g[i]=g[i+1]*(i+1ull)%mod;
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];
DFT(f,1<<len,len+1);DFT(g,1<<len,len+1);px(f,g,1<<len);IDFT(f,1<<len,len+1);
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);
}

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. imagenamed和imageWithContentOfFile的区别

    @implementation ViewController /** 图片的两种加载方式: 1> imageNamed: a. 就算指向它的指针被销毁,该资源也不会被从内存中干掉 b. 放到As ...

  2. ImageMagick转换图片格式

    /usr/bin/convert data/manager/tongji/Html/WebData/images/code0/xingfumima0_1000_0.jpg -colorspace cm ...

  3. SpringDataJpa打印Sql详情(含参数)

    Spring Data Jpa打印Sql详情(带sql参数) 这里使用的是 log4jdbc,yml配置文件里的数据源配置也要做相应的修改 pom文件引入 <dependency> < ...

  4. 【AGC035D】Add and Remove(脑洞 DP 分治)

    题目链接 大意 给出\(N\)个数的序列,每次操作可以选择连续的三个数,将中间的那个数抽出,将另外两个数的数值加上中间那个数的数值. 一直执行以上操作直到只剩最后两个数,求最后两个数的所有可能的和的最 ...

  5. Hadoop完全分布式的配置

    选取机器sam01作为主节点,并进行分布式文件的配置 1.进入Hadoop配置文件路径/usr/local/hadoop/etc/hadoop(这里我把Hadoop安装在/usr/local目录下) ...

  6. treevalue——Master Nested Data Like Tensor

    首先,请和我一起高呼--"treevalue--通用树形结构建模工具 + 极简树形结构编程模型". 咳咳,好久没更新了,这一次是真的好久不见,甚是想念.在之前的三期中,关于 tre ...

  7. 从零开始学mitmproxy抓包工具

    Man In The Middle mitm是Man In The Middle的首字母缩写,意思是位于中间的人,表明mitmproxy是一个代理,可以拦截请求,实现网络抓包.知名的网络抓包工具有Fi ...

  8. 北京太速科技-第六代Intel i7四核八线程6U VPX主控板

    一.产品概述 该产品是一款基于第六代Intel i7四核八线程的高性能6U VPX刀片式计算机.产品提供了可支持全网状交换的高速数据通道,其中P1,P2各支持4个PCIe x4 Gen3总线接口,P3 ...

  9. C#使用 WebRequest 异步获取网页并自动忽略SSL证书

    C#使用 WebRequest 模拟浏览器请求访问网页并自动忽略HTTPS安全证书 以下两个C#异步方法,封装了WebRequest请求,支持忽略SSL证书. 作者:张赐荣 1.Get请求      ...

  10. suse 12 二进制部署 Kubernetets 1.19.7 - 第07章 - 部署kube-controller-manager组件

    文章目录 1.7.部署kube-controller-manager 1.7.0.创建kube-controller-manager请求证书 1.7.1.生成kube-controller-manag ...