#拉格朗日插值,线性筛#洛谷 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> ...
随机推荐
- 时序数据库timescaleDB安装
一:前言相关 环境:Red Hat 8.3.1-5安装程序:PostgreSQL 14.1,TimescaleDB 2.5.1,cmake3.22.1PostgreSQL编译安装需要cmake3.4以 ...
- java基础字符串---02
String 概述 String类在java.lang包下,所以使用的时候不需要导包 String类代表字符串,java程序中的所有字符串文字(例如"abc")都被实现为此类的实例 ...
- Kotlin 协程二 —— 通道 Channel
目录 一. Channel 基本使用 1.1 Channel 的概念 1.2 Channel 的简单使用 1.3 Channel 的迭代 1.4 close 关闭 Channel 1.5 Channe ...
- Navicat安装包和激活工具
链接:https://pan.baidu.com/s/11YuOKdgGakt3E8CL80aA2g 提取码:h4f3
- c# 4.8 实现Windows 定时任务计划(Task Scheduler)
分享一个我自己写的 Windows 定时任务计划(Task Scheduler) 动态创建代码,没做太多封装,留个实现笔记 首先封装一个简单配置项的类 1 public class TaskSched ...
- 【Azure 环境】记录使用Notification Hub,安卓手机收不到Push通知时的错误,Error_Code 30602 or 30608
问题描述 使用Azure Notification Hub + Baidu 推送遇见的两次报错为: 1. {"request_id":2921358089,"error_ ...
- Linux 多进程服务配置 systemd
目录 Linux 多进程服务配置 systemd sysvinit和systemd 多进程保活 创建配置文件(设定重试次数) 多进程服务管理 链式启动(服务依赖) 指定关闭进程方式 - ExecSto ...
- CSV转Excel,命中关键词标红
CSV转Excel,命中关键词标红 package com.wenwo.schedule.job.mainJob; import java.io.ByteArrayOutputStream; impo ...
- 个性化的单芯片的回声消除(AEC)解决方案
概述 这些年随着智能化产品的广泛应用,各种新型音频产品也层出不穷,在这个古老的领域,传统的回声消除方案一般是功耗高,成本非常高,集成性差.无法满足新产品新市场对回声消除的低成本低功耗个性化需求等特 ...
- uni学习笔记分享
目录介绍 01.遇到问题汇总 02.关于布局设置 03.基础语法总结 04.关于交互问题 06.关于回传数据 07.关于网络请求 08.关于页面刷新 09.关于注意问题 10.待解决和思考 01.遇到 ...