题意很明确,不说了。

前置芝士:单位根反演

也就是:

\[[n|a]=\frac 1 n \sum_{i=0}^{n-1}w_n^{ai}
\]

看到题目给的柿子:

\[\sum_{i=0}^n\binom n i \times p^i \times \lfloor \frac i k \rfloor
\]

先把那个向下取整拆开:

\[\sum_{i=0}^n\binom n i \times p^i \times \frac {i- i \bmod k} k
\]
\[\frac 1 k \times (\sum_{i=0}^n\binom n i \times p^i \times i - \sum_{i=0}^n\binom n i \times p^i \times i \bmod k)
\]

先看左边的:

\[\sum_{i=0}^n \binom n i\times p^i \times i
\]

由于 \(i\) 这里很难使用二项式定理,又不能爆算,所以考虑通过某种方式把 \(i\) 搞掉,给出引理:

\[\binom n m m = \binom {n-1} {m-1} n
\]

证明是:

\[\binom n m = \frac {n!} {(n-m)!m!}m = \frac {(n-1)!} {(n-m)!(m-1)!}n = \binom {n-1} {m-1}n
\]

于是:

\[np\sum_{i=0}^n\binom {n-1} {i-1} p^i
\]

然后使用二项式定理:

\[np(p+1)^{n+1}
\]

现在看向右边:

\[\sum_{i=0}^n\binom n i \times p^i \times i \bmod k
\]

按照做莫反题的经验,枚举余数:

\[\sum_{i=0}^n\binom n i p^i\sum_{t=0}^{k-1}t[i-t \bmod k =0]
\]

单位根反演一下:

\[\frac 1 k\sum_{i=0}^n\binom n i p^i\sum_{t=0}^{k-1}t\sum_{j=0}^{k-1}w_k^{(i-t)j}
\]
\[\frac 1 k\sum_{i=0}^n\binom n i p^i\sum_{t=0}^{k-1}t\sum_{j=0}^{k-1}w_k^{ij}w_k^{-tj}
\]
\[\frac 1 k\sum_{j=0}^{k-1}\sum_{t=0}^{k-1}tw_k^{-tj}\sum_{i=0}^n\binom n i p^iw_k^{ij}
\]
\[\frac 1 k\sum_{j=0}^{k-1}(pw_k^j+1)^n\sum_{t=0}^{k-1}tw_k^{-tj}
\]

于是我们考虑怎么快速计算 \(\sum_{i=0}^{n-1}ik^i\)

这看上去很像等比数列,按照等比数列求和公式的推导对这玩意儿做一遍:

为了方便,先设这玩意儿为 \(f(n,k)\)

\[kf(n,k)-f(n,k)=\sum_{i=0}^{n-1}ik^{i+1}-\sum_{i=0}^{n-1}ik^i
\]
\[\sum_{i=1}^n(i-1)k^i-\sum_{i=0}^{n-1}ik^i
\]
\[(n-1)k^n-\sum_{i=1}^{n-1}k^i
\]
\[(n-1)k^n-\frac {k^n-k} {k-1}
\]

又因为带入的都是 \(k\) 次单位根,所以上式的 \(k^n=1\)。于是:

\[n-1+\frac {1-k}{k-1}=n
\]

所以 \(f(n,k) =\frac n {k-1}\),注意要特判 \(f(n,1) = \frac {n(n-1)} 2\)

整理一下:

\[\frac 1 k \times ( np(p+1)^{n+1} - \frac 1 k\sum_{j=0}^{k-1}(pw_k^j+1)^nf(k,w_k^{-j}) )
\]

贴代码:

#include<cstdio>
const int M=1<<23|5,mod=998244353;
int n,p,k,ans,w[M];
inline int pow(int a,int b=mod-2){
int ans=1;
for(;b;b>>=1,a=1ll*a*a%mod)if(b&1)ans=1ll*ans*a%mod;
return ans;
}
inline int Add(const int&a,const int&b){
return a+b>=mod?a+b-mod:a+b;
}
inline int f(const int&n,const int&k){
if(k==1)return (1ll*n*(n-1)>>1)%mod;
return 1ll*n*pow(k-1)%mod;
}
signed main(){
int i;
scanf("%d%d%d",&n,&p,&k);
w[0]=1;w[1]=pow(3,(mod-1)/k);
for(i=2;i<=k;++i)w[i]=1ll*w[i-1]*w[1]%mod;
for(i=0;i<k;++i)ans=Add(ans,1ll*pow((1ll*p*w[i]+1)%mod,n)*f(k,w[k-i])%mod);
ans=(1ll*n*p%mod*pow(p+1,n-1)%mod-1ll*ans*pow(k)%mod+mod)%mod;
printf("%d",1ll*ans*pow(k)%mod);
}

LGP5591题解的更多相关文章

  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. 4、网络并发编程--僵尸进程、孤儿进程、守护进程、互斥锁、消息队列、IPC机制、生产者消费者模型、线程理论与实操

    昨日内容回顾 操作系统发展史 1.穿孔卡片 CPU利用率极低 2.联机批处理系统 CPU效率有所提升 3.脱机批处理系统 CPU效率极大提升(现代计算机雏形) 多道技术(单核CPU) 串行:多个任务依 ...

  2. Keras学习:试用卷积-训练CIFAR-10数据集

    import numpy as np import cPickle import keras as ks from keras.layers import Dense, Activation, Fla ...

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

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

  4. Latex公式导出word,Latex转换MathML使用POI导出公式可编辑的Word文件

    背景 之前在 使用spire.doc导出支持编辑Latex公式的标准格式word 博客中写过,使用spire.doc来生成word,不得不说spire.doc的api操作起来还是比较方便,但是使用的过 ...

  5. 云原生 PostgreSQL 集群 - PGO:来自 Crunchy Data 的 Postgres Operator

    使用 PGO 在 Kubernetes 上运行 Cloud Native PostgreSQL:来自 Crunchy Data 的 Postgres Operator! Cloud Native Po ...

  6. Oracle数据库-常规中行显示0,解决方案

    如图,如果当前位置显示为0  原因:Oracle不是实时的对表进行分析的,需要手动执行分析. 解决方案: 分析表 analyze table tablename compute statistics;

  7. archery关闭导出功能

    https://github.com/hhyo/Archery/issues/1367 进入docker容器,找到sqlquery.html.修改showExport相关配置为以下内容. {% if ...

  8. Android SugarORM(2)

    Android Sugar ORM (2) Android Sugar ORM 实体 1. 创建一个实体类 Sugar ORM在创建一个实体的时候, 仅需要使这个实体类继承于SugarRecord即可 ...

  9. ctf平台

    CTF靶场 蓝鲸安全:http://whalectf.xin bugku:https://ctf.bugku.com XCTF攻防世界:https://adworld.xctf.org.cn/ i春秋 ...

  10. [杂记]LeTeX中使用tikz画图的一些实例

    出处:http://www.texample.net/tikz/examples/all/ 上述网站中的实例非常丰富,将代码修改一下再编译就能明白是什么意思,故不再赘述.