这个柿子挺别致的......还有信仰膜数998244353


直接讲正解吧......

首先发现这个柿子从上往下算好像不怎么行,我们从下往上看,(下面令\(Ans_r = sum_{k,1,r}\))。

考虑\(a_i\)对\(Ans_r\)的贡献(\(1 \le i \le r\)),即\(a_i\)在\(sum_{k,1,r}\)中被算了多少次,我们假设\(a_i\)被算了\(c_i\)次。答案就是\(Ans_r = \sum\limits_{i = 1} ^ r a_i c_i\) 废话。

这个\(c_i\)显然是位置\(i\)在\([1,r]\)中被\(k-1\)重区间覆盖的方案数。

逼格高一点就是选\(k-1\)个(减一是因为最大的区间已经定下来是\([1,r]\)了)区间\([l_1,r_1],[l_2,r_2],\cdots,[l_{k-1},r_{k-1}]\),使得\(1 \le l_i,r_i \le r,[l_i, r_i] \subset [l_{i+1}, r_{i+1}]\)且\(l_1 \le i \le r_1\)的方案数。

这个就是在\(1...i\)选\(k-1\)个位置(可重复)的方案数\(\times\)在\(i...r\)里选\(k-1\)个位置(可重复)的方案数。

有\(c_i = s(i,k-1) s(r-i+1,k-1)\),其中\(s(n,m)\)表示在一个有\(n\)种元素,每种元素有无限个的集合内选\(m\)个元素出来做组合的方案数。

下面我们来推\(s\)。

我们手里有一个有\(n\)个元素的集合,且每种元素有无限个。

实际上\(s(n,m)\)就等价于\(x_1 + x_2 + \cdots + x_n = m\)的非负整数解的个数,\(x_i\)表示第\(i\)种元素选了多少个。

经典的隔板法吧。这个好像小学奥数就有......

他就等价于这个集合的全排个数

\[T = \{ m \cdot 1, (n-1) \cdot \text{|} \}
\]

可以理解为把\(m\)个\(1\)用\((n-1)\)个板子隔开来,那么相邻两个板子之间,以及左右两边就代表了一个$x_1...x_n $

即\(s(n,m) = \frac{(m+n-1)!}{m!(n-1)!} = \binom{n+m-1}{m}\)

那么\(c_i = \binom{i + k-2}{k-1}\binom{r-i+k-1}{k-1}\)

写回\(Ans_r\)就是

\[Ans_r = \sum\limits_{i = 1}^{r} a_ic_i = \sum\limits_{i = 1} ^ r a_i \binom{i + k - 2}{k-1}\binom{r-i+k-1}{k-1}
\]

这个柿子非常卷积吧!

我们令\(g_i = \binom{i + k - 1}{k - 1}\),\(f_i = \binom{i + k - 2}{k-1}a_i\),那么

\[Ans_r = \sum\limits_{i = 1} ^ r f_ig_{r-i}
\]

因为有信仰质数\(998244353\),\(NTT\)一下就没了。

还有由于\(k\)很大,我们可以递推出\(g\),然后用\(f_i = a_i g_{i-1}\)来算\(f\)。

#include <bits/stdc++.h>
using namespace std;
const int N=3e5+10,P=998244353,G=3,IG=(P+1)/G;
inline int fpow(int a,int b){
int ret=1; for (;b;b>>=1,a=1ll*a*a%P)
if (b&1) ret=1ll*a*ret%P;
return ret;
}
inline int add(int x,int y){return x+y>=P?x+y-P:x+y;}
inline int sub(int x,int y){return x-y<0?x-y+P:x-y;}
int rev[N];
void init(int limit){
for (int i=0;i<limit;i++)rev[i]=rev[i>>1]>>1|((i&1)?limit>>1:0);
}
void ntt(int *f,int n,int flg){
for (int i=0;i<n;i++) if (rev[i]<i)swap(f[i],f[rev[i]]);
for (int len=2,k=1;len<=n;len<<=1,k<<=1){
int wn=fpow(flg==1?G:IG,(P-1)/len);
for (int i=0;i<n;i+=len){
for (int w=1,j=i;j<i+k;j++,w=1ll*w*wn%P){
int tmp=1ll*w*f[j+k]%P;
f[j+k]=sub(f[j],tmp),f[j]=add(f[j],tmp);
}
}
}
if (flg==-1){
int inv=fpow(n,P-2);
for (int i=0;i<n;i++)f[i]=1ll*f[i]*inv%P;
}
}
int f[N],g[N],a[N],inv[N];
int main(){
int n,k; scanf("%d%d",&n,&k);
for (int i=1;i<=n;i++)scanf("%d",&a[i]);
inv[1]=1; for (int i=2;i<=n;i++) inv[i]=1ll*inv[P%i]*(P-P/i)%P; // 线性推逆元
g[0]=1,g[1]=k%P; for (int i=2;i<=n;i++)
g[i]=1ll*g[i-1]*inv[i]%P*(i+k-1)%P; // 颓g
for (int i=1;i<=n;i++) f[i]=1ll*a[i]*g[i-1]%P; // 颓f
int limit=1; while(limit<=n*2)limit<<=1; init(limit);
ntt(f,limit,1),ntt(g,limit,1);
for (int i=0;i<limit;i++) f[i]=1ll*f[i]*g[i]%P;
ntt(f,limit,-1);
for (int i=1;i<=n;i++) printf("%d ",f[i]);
return 0;
}

[题解] Luogu P5641 【CSGRound2】开拓者的卓识的更多相关文章

  1. [题解] Luogu P5446 [THUPC2018]绿绿和串串

    [题解] Luogu P5446 [THUPC2018]绿绿和串串 ·题目大意 定义一个翻转操作\(f(S_n)\),表示对于一个字符串\(S_n\), 有\(f(S)= \{S_1,S_2,..., ...

  2. 题解 Luogu P2499: [SDOI2012]象棋

    关于这道题, 我们可以发现移动顺序不会改变答案, 具体来说, 我们有以下引理成立: 对于一个移动过程中的任意一个移动, 若其到达的位置上有一个棋子, 则该方案要么不能将所有棋子移动到最终位置, 要么可 ...

  3. 题解 luogu P1144 【最短路计数】

    本蒟蒻也来发一次题解第一篇请见谅 这个题有几个要点 1.无向无权图,建图的时候别忘记建来回的有向边[因此WA掉1次 2.无权嘛,那么边长建成1就好了2333333 3.最短路采用迪杰斯特拉(别忘用堆优 ...

  4. 题解 Luogu P1110 【[ZJOI2007]报表统计】

    感谢 @cmy962085349 提供的hack数据,已经改对了. 先声明,我好像是题解里写双$fhq$ $treap$里唯一能过的...(最后两个点啊) 思路:首先看题目,$MIN_GAP_SORT ...

  5. 题解 Luogu P3370

    讲讲这题的几种做法: 暴力匹配法 rt,暴力匹配,即把字符串存起来一位一位判相等 时间复杂度$ O(n^2·m) $ 再看看数据范围 \(n\le10^5,m\le10^3\) 当场爆炸.当然有暴力分 ...

  6. 题解 Luogu P3623 [APIO2008]免费道路

    [APIO2008]免费道路 题目描述 新亚(New Asia)王国有 N 个村庄,由 M 条道路连接.其中一些道路是鹅卵石路,而其它道路是水泥路.保持道路免费运行需要一大笔费用,并且看上去 王国不可 ...

  7. [题解]luogu P4116 Qtree3

    终于来到了Qtree3, 其实这是Qtree系列中最简单的一道题,并不需要线段树, 只要树链剖分的一点思想就吼了. 对于树链剖分剖出来的每一根重链,在重链上维护一个Set就好了, 每一个Set里存的都 ...

  8. 题解 Luogu P3959 【宝藏】

    来一篇不那么慢的状压??? 话说这题根本没有紫题难度吧,数据还那么水 我是不会告诉你我被hack了 一看数据规模,n≤12,果断状压. 然后起点要枚举,就设dp状态: f[i][j]=以i为起点到j状 ...

  9. 题解 Luogu P1099 【树网的核】

    这题是真的水啊... ------------ 昨天模拟赛考了这题,很多人都是O($n^3$)水过,但我认为,要做就做的足够好(其实是我根本没想到O($n^3$)的做法),然后就开始想O(n)的解法. ...

随机推荐

  1. mysql分区介绍

    http://www.cnblogs.com/chenmh/p/5644713.html 介绍 可以针对分区表的每个分区指定各自的存储路径,对于innodb存储引擎的表只能指定数据路径,因为数据和索引 ...

  2. 十三: 悲观锁&乐观锁:解决丢失更新问题

    悲观锁:认为丢失更新一定会出现,可以在查询的时候加入for update 认为丢失更新一定会出现,查询时: select * from account for update;for update :  ...

  3. django+centos+mariadb读写分离完美实现(上)-mysql主从备份实现

    首先画图一张,用来展示今天要做的事情,读写分离,个人理解就是使用mysql主从备份的原理,让两个数据库同时为自己提供服务.其中主库负责数据保存,从库负责数据展示,可以一主一从,也可以一主多从.从而降低 ...

  4. PowerShell的一些资料整理

    年后准备把一些公司的一些祖传脚本给重新弄下,之前的脚本是bat写的,又臭又长,这次就不准备补窟窿了.打算用powershell重写下,这里就整理了一些相关的技术资料. 入门教程: 入门教程可以首选国内 ...

  5. CSS样式表——样式2

    样式 5)边界边框 margin:0px;                                            //外边距为0 margin:10px 0px 0px 10px;   ...

  6. Linux添加虚拟内存 && 修改Linux系统语言

    Linux添加虚拟内存 首先执行free -h查看内存状况: total used free shared buff/cache available Mem: 1.8G 570M 76M 8.4M 1 ...

  7. 中兴获25个5G商用合同

    网易科技讯,6 月 25 日消息,在 2019 年 MWC 上海展期间,中兴通讯宣布随着全球首批 5G 规模商用部署展开,已在全球获得 25 个 5G 商用合同,覆盖中国.欧洲.亚太.中东等主要 5G ...

  8. nodejs 文件路径问题

    fs.stat()  是 获取 本目录下 文件信息 的方法 .如果使用要加上绝对路径.不然会出问题.例: 解决方法

  9. 抓取屏幕并压缩生成HBITMAP

    HBITMAP GetScreenBmp() { HWND hwnd = ::GetDesktopWindow(); HDC hsrc = ::GetDC(hwnd); HDC hmemdc = :: ...

  10. 中文文本分类之CharCNN

    文本分类是自然语言处理中一个非常经典的任务,可用的模型非常多,相关的开源代码也非常多了.这篇博客用一个CNN模型,对新闻文本进行分类. 全部代码有4个模块:1.数据处理模块(命名为:cnews_loa ...