#拉格朗日插值,线性筛#洛谷 5442 【XR-2】约定 (加强版)
题目
一个\(n\)个点的完全图,
第\(i\)个点到第\(j\)个点的边权是\((i+j)^k\),
现在把这个完全图变成一棵树,
求这棵树边权和的期望值
\((n\leq 10^{10000},k\leq 10^7,mod=998244353)\)
分析
因为\(n\)个结点的完全图的生成树个数为\(n^{n-2}\),
每条边在生成树中出现的次数是\(\frac{(n-1)n^{n-2}}{\frac{n(n-1)}{2}}=2n^{n-3}\)
所以应该
\]
考虑差分
\]
对于单个正整数幂,因为它是积性函数,所以可以线性筛
后面这个东西脑补一下应该是一个\(k+2\)次多项式,
可以通过拉格朗日插值实现,因为这些值是连续的,所以可以\(O(k)\)实现
弱化版讲完了,由于\(n\)在模意义下可能为0,所以要特判
用\(998244353^2\)作新模数,如果最后\(n\)在模意义下不存在逆元,
可以证明答案是998244353的倍数,那么直接除掉就可以了
不过常数超级大,比多项式做法慢多了
代码
#include <cstdio>
#include <cctype>
#define rr register
using namespace std;
typedef long long lll; typedef long double ld;
const lll mod=996491788296388609ll,N=2e7+11,rmod=998244353;
lll n,f[N],fac[N>>1],jc[N>>1],inv[N>>1]; int k,lim,Cnt,prime[1300001];
inline lll mol(lll a,lll b){
rr lll c=(ld)a*b/mod,ans=a*b-c*mod;
ans=ans<0?ans+mod:(ans>=mod?ans-mod:ans);
return ans;
}
inline lll mo1(lll x,lll y){return x+y>=mod?x+y-mod:x+y;}
inline lll mo2(lll x,lll y){return x<y?x-y+mod:x-y;}
inline lll ksm(lll x,lll y){
rr lll ans=1;
for (;y;y>>=1,x=mol(x,x))
if (y&1) ans=mol(ans,x);
return ans;
}
inline lll answ(){
jc[0]=jc[1]=fac[0]=1;
for (rr int i=2;i<=lim;++i) jc[i]=mol(jc[i-1],i);
rr lll prod=1,ans=0;
for (rr int i=1;i<=lim;++i){
prod=mol(prod,n-i);
inv[i]=fac[i]=mol(mol(jc[i-1],jc[lim-i]),n-i);
}
for (rr int i=1;i<=lim;++i) fac[i]=mol(fac[i],fac[i-1]);
fac[lim]=ksm(fac[lim],mod-2);
for (rr int i=lim;i;--i){
rr lll t=inv[i];
inv[i]=mol(fac[i-1],fac[i]),
fac[i-1]=mol(t,fac[i]);
}
for (rr int i=1;i<=lim;++i){
rr lll t=mol(mol(f[i],prod),inv[i]);
ans=mo1(ans,((lim^i)&1)?mod-t:t);
}
return ans;
}
inline signed rksm(int x,int y){
rr int ans=1;
for (;y;y>>=1,x=1ll*x*x%rmod)
if (y&1) ans=1ll*ans*x%rmod;
return ans;
}
signed main(){
rr char c=getchar();
while (!isdigit(c)) c=getchar();
while (isdigit(c)) n=(n*10+c-48)%rmod,c=getchar();
scanf("%d",&k),f[1]=1,n=n<1?n+rmod:n,lim=(n<k+2?n+1:k+3)<<1;
for (rr int i=2;i<=lim;++i){
if (!f[i]) f[prime[++Cnt]=i]=ksm(i,k);
for (rr int j=1;j<=Cnt&&prime[j]<=lim/i;++j){
f[i*prime[j]]=mol(f[i],f[prime[j]]);
if (i%prime[j]==0) break;
}
}
for (rr int i=2;i<=lim;++i) f[i]=mo1(f[i],f[i-1]); lim>>=1;
for (rr int i=0;i<lim;++i) f[i+1]=mo1(f[i],mo2(f[i<<1|1],f[i+1]));
rr lll ans=n<=lim?f[n]:answ(); ans=mo1(ans,ans);
if (n%rmod) printf("%lld",ans%rmod*rksm(n,rmod-2)%rmod);
else printf("%lld",ans/rmod);
return 0;
}
#拉格朗日插值,线性筛#洛谷 5442 【XR-2】约定 (加强版)的更多相关文章
- 洛谷P1120 小木棍 [数据加强版](搜索)
洛谷P1120 小木棍 [数据加强版] 搜索+剪枝 [剪枝操作]:若某组拼接不成立,且此时 已拼接的长度为0 或 当前已拼接的长度与刚才枚举的长度之和为最终枚举的答案时,则可直接跳出循环.因为此时继续 ...
- 埃氏筛优化(速度堪比欧拉筛) + 洛谷 P3383 线性筛素数 题解
我们一般写的埃氏筛消耗的时间都是欧拉筛的三倍,但是欧拉筛并不好想(对于我这种蒟蒻) 虽然 -- 我 -- 也可以背过模板,但是写个不会的欧拉筛不如写个简单易懂的埃氏筛 于是就有了优化 这个优化还是比较 ...
- Solution -「洛谷 P4449」于神之怒加强版
\(\mathcal{Description}\) Link. 给定 \(k\) 和 \(T\) 组 \(n,m\),对于每组,求 \[\sum_{i=1}^n\sum_{j=1}^m\ope ...
- 洛谷P2045 方格取数加强版(费用流)
题意 题目链接 Sol 这题能想到费用流就不难做了 从S向(1, 1)连费用为0,流量为K的边 从(n, n)向T连费用为0,流量为K的边 对于每个点我们可以拆点限流,同时为了保证每个点只被经过一次, ...
- 洛谷 P2045 方格取数加强版【费用流】
题目链接:https://www.luogu.org/problemnew/show/P2045 题目描述 给出一个n*n的矩阵,每一格有一个非负整数Aij,(Aij <= 1000)现 ...
- 洛谷P2812 校园网络[数据加强版] [Tarjan]
题目传送门 校园网络 题目背景 浙江省的几所OI强校的神犇发明了一种人工智能,可以AC任何题目,所以他们决定建立一个网络来共享这个软件.但是由于他们脑力劳动过多导致全身无力身体被♂掏♂空,他们来找你帮 ...
- 洛谷P1368 均分纸牌(加强版)
P1368 均分纸牌(加强版) 题目描述 有 N 堆纸牌,编号分别为 1,2,…, N.每堆上有若干张,纸牌总数必为 N 的倍数.可以在任一堆上取1张纸牌,然后移动. 移牌规则为:在编号为 1 堆上取 ...
- 洛谷 P1120 小木棍[数据加强版]
这道题可能是我做过的数据最不水的一道题-- 题目传送门 这题可以说是神剪枝,本身搜索并不算难,但剪枝是真不好想(好吧,我承认我看了题解)-- 剪枝: 用桶来存储木棍 在输入的时候记录下最长的木棍和最短 ...
- 洛谷 - P2045 - 方格取数加强版 - 费用流
原来这种题的解法是费用流. 从一个方格的左上走到右下,最多走k次,每个数最多拿走一次. 每次走动的流量设为1,起始点拆点成限制流量k. 每个点拆成两条路,一条路限制流量1,费用为价值相反数.另一条路无 ...
- 洛谷P2045 方格取数加强版 最小费用流
Code: #include<cstdio> #include<cstring> #include<algorithm> #include<queue> ...
随机推荐
- xHook 源码解析
xHook 是爱奇艺开源的一个PLT Hook 框架 项目地址: https://github.com/iqiyi/xHook 该项目实现了 PTL/GOT Hook PTL hook 的本质是修改内 ...
- 教你如何判断Java代码中异步操作是否完成
本文分享自华为云社区<java代码实现异步返回结果如何判断异步执行完成>,作者: 皮牙子抓饭. 在许多应用程序中,我们经常使用异步操作来提高性能和响应度.在Java中,我们可以使用多线程或 ...
- nginx中使用perl脚本来定制一些请求转发等等
http://t.zoukankan.com/carriezhangyan-p-9359708.html https://blog.csdn.net/weixin_28917223/article/d ...
- 迭代器,map,filter,reduce,sorted函数---day12
1.迭代器 迭代器能被next调用,并不断返回下一个值的对象,叫作迭代器(迭代器是对象) 概念:迭代器指的是迭代取值的工具,迭代是一个重复的过程每次重复都是基于上一次的结果而继续单纯的重复不是迭代. ...
- Gin框架入门
参考文档 Gin: https://gin-gonic.com/zh-cn/docs/quickstart/ net/http: https://pkg.go.dev/net/http 代码分析 pa ...
- 01、etcd基础介绍
互联网技术发展真的快,层出不穷的新技术.最近项目使用到了etcd,自己之前在部署k8s集群的时候玩过,但是并没有系统的学习.正好趁这个机会,系统性的学习下.文章中的内容有些是来自官方文档,有些是来自网 ...
- C笔记(2014-12备份)
Video1: 1-编译器对待全局变量和局部变量的差别.全局变量分配空间是在数据区,局部变量分配在代码区. (比如局部变量 int lo_var = 2;后面的 = 2;是赋值语句,被编译器转化成机器 ...
- linux虚拟机初始配置
1- CentOS7配置静态IP地址: iface="网络接口名"cd /etc/sysconfig/network-scripts/; sed -i 's/^/#/' ifcfg ...
- Taurus.MVC WebMVC 入门开发教程6:路由配置与路由映射
前言: 在本篇 Taurus.MVC WebMVC 入门开发教程的第六篇文章中, 我们将讨论如何配置路由并映射到控制器和操作方法. 路由是决定应用程序如何响应客户端请求的重要组成部分,因此在 Web ...
- Tiktok api接口 获取视频列表、用户详情,视频无水印数据采集
iDataRiver平台 https://www.idatariver.com/zh-cn/ 提供开箱即用的Tiktok数据采集API,供用户按需调用. 接口使用详情请参考Tiktok接口文档 接口列 ...