【BZOJ5093】图的价值(第二类斯特林数,组合数学,NTT)

题面

BZOJ

题解

单独考虑每一个点的贡献:

因为不知道它连了几条边,所以枚举一下

\[\sum_{i=0}^{n-1}C_{n-1}^i·i^k·2^{\frac{n(n-1)}{2}}
\]

因为有\(n\)个点,所以还要乘以一个\(n\)

所以,我们真正要求的就是:

\[\sum_{i=0}^{n-1}C_{n-1}^i·i^k
\]

怎么做?

看到了\(i^k\)想到了第二类斯特林数

\[m^n=\sum_{i=0}^{m}C_{m}^{i}·S(n,i)·i!
\]

所以把这个东西带回去

\[\sum_{i=0}^{n-1}C_{n-1}^i·i^k
\]

\[=\sum_{i=0}^{n-1}C_{n-1}^i·\sum_{j=0}^{i}S(k,j)·C_{i}^{j}·j!
\]

如果\(n\)在前面是没法算的,即使\(O(N)\)也是不行的

所以把后面的\(j\)丢到前面去

\[\sum_{j=0}^{n-1}S(k,j)·j!\sum_{i=j}^{n-1}C_{n-1}^iC_{i}^j
\]

后面那个是啥呢?

我们来考虑一下组合意义

有\(n-1\)个球从中选出\(i\)个染成黑色

再从\(i\)个黑球中选出\(j\)个染成白色

既然染成白色的球固定是\(j\)个

那么,我可以想先从\(n-1\)个球中选出\(j\)个直接染成白色

因为\(i\)个枚举的,相当于我可以取出任意个数染成黑色

既然有\(j\)个白球了,剩下\(n-1-j\)个球,染色或者不染色都是可以的

所以就再乘上\(2^{n-1-j}\)

\[\sum_{j=0}^{n-1}S(k,j)·j!\sum_{i=j}^{n-1}C_{n-1}^iC_{i}^j
\]

\[=\sum_{j=0}^{n-1}S(k,j)·j!·C_{n-1}^j·2^{n-1-j}
\]

\[=\sum_{j=0}^{n-1}S(k,j)·j!·\frac{(n-1)!}{j!(n-j-1)!}·2^{n-1-j}
\]

\[=\sum_{j=0}^{n-1}S(k,j)·j!·\frac{(n-1)!}{j!(n-j-1)!}·2^{n-1-j}
\]

\[=\sum_{j=0}^{n-1}S(k,j)·\frac{(n-1)!}{(n-j-1)!}·2^{n-1-j}
\]

至于\(S(k,j)\)怎么算?

不要忘记第二类斯特林数也是一个卷积的形式

戳这里去看看

那么,先算出第二类斯特林数,直接算就好啦

当然啦,对于\(j>k\),\(S(k,j)=0\)就不用枚举了

所以最多枚举到\(k\)

复杂度\(O(klogk)\)

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<set>
#include<map>
#include<vector>
#include<queue>
using namespace std;
#define ll long long
#define RG register
#define MOD 998244353
#define MAX 1000000
const int pr=3;
const int phi=MOD-1;
int fpow(int a,int b)
{
int s=1;
while(b){if(b&1)s=1ll*s*a%MOD;a=1ll*a*a%MOD;b>>=1;}
return s;
}
int N,M,l,a[MAX],b[MAX],S[MAX],r[MAX];
void NTT(int *P,int opt)
{
for(int i=0;i<N;++i)if(i<r[i])swap(P[i],P[r[i]]);
for(int i=1;i<N;i<<=1)
{
int W=fpow(pr,phi/(i<<1));
for(int p=i<<1,j=0;j<N;j+=p)
{
int w=1;
for(int k=0;k<i;++k,w=1ll*w*W%MOD)
{
int X=P[j+k],Y=1ll*w*P[i+j+k]%MOD;
P[j+k]=(X+Y)%MOD;P[i+j+k]=((X-Y)%MOD+MOD)%MOD;
}
}
}
if(opt==-1)reverse(&P[1],&P[N]);
}
void Work()
{
M+=N;
for(N=1;N<=M;N<<=1)++l;
for(int i=0;i<N;++i)r[i]=(r[i>>1]>>1)|((i&1)<<(l-1));
NTT(a,1);NTT(b,1);
for(int i=0;i<N;++i)a[i]=1ll*a[i]*b[i]%MOD;
NTT(a,-1);
for(int i=0,inv=fpow(N,MOD-2);i<N;++i)a[i]=1ll*a[i]*inv%MOD;
}
int n,K,jc[MAX],inv[MAX],ans;
int main()
{
scanf("%d%d",&n,&K);
jc[0]=inv[0]=1;
for(int i=1;i<=K;++i)jc[i]=1ll*jc[i-1]*i%MOD;
for(int i=1;i<=K;++i)inv[i]=fpow(jc[i],MOD-2);
N=M=K;
for(int i=0;i<=K;++i)a[i]=(i&1)?MOD-inv[i]:inv[i];
for(int i=0;i<=K;++i)b[i]=1ll*fpow(i,K)*inv[i]%MOD;
Work();
for(int i=0;i<=K;++i)S[i]=a[i];
int inv2=fpow(2,MOD-2);
for(int i=0,p=fpow(2,n-1),pp=1;i<=min(n-1,K);++i)
{
int t=1ll*S[i]*pp%MOD*p%MOD;
p=1ll*p*inv2%MOD;
pp=1ll*pp*(n-1-i)%MOD;
ans=(ans+t)%MOD;
}
ans=1ll*ans*n%MOD;
ans=1ll*ans*fpow(2,1ll*(n-1)*(n-2)/2%phi)%MOD;
printf("%d\n",ans);
return 0;
}

【BZOJ5093】图的价值(第二类斯特林数,组合数学,NTT)的更多相关文章

  1. BZOJ 5093: [Lydsy1711月赛]图的价值 第二类斯特林数+NTT

    定义有向图的价值为图中每一个点的度数的 \(k\) 次方之和. 求:对于 \(n\) 个点的无向图所有可能情况的图的价值之和. 遇到这种题,八成是每个点单独算贡献,然后累加起来. 我们可以枚举一个点的 ...

  2. bzoj 5093 图的价值 —— 第二类斯特林数+NTT

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=5093 每个点都是等价的,从点的贡献来看,得到式子: \( ans = n * \sum\li ...

  3. bzoj 5093 [Lydsy1711月赛]图的价值——第二类斯特林数

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=5093 不要见到组合数就拆! 枚举每个点的度数,则答案为 \( n*\sum\limits_{ ...

  4. 【洛谷2791】幼儿园篮球题(第二类斯特林数,NTT)

    [洛谷2791]幼儿园篮球题(第二类斯特林数,NTT) 题面 洛谷 题解 对于每一组询问,要求的东西本质上就是: \[\sum_{i=0}^{k}{m\choose i}{n-m\choose k-i ...

  5. 【XSY1301】原题的价值 第二类斯特林数 NTT

    题目描述 给你\(n,m\),求所有\(n\)个点的简单无向图中每个点度数的\(m\)次方的和. \(n\leq {10}^9,m\leq {10}^5\) 题解 \(g_n\)为\(n\)个点的无向 ...

  6. 【bzoj5093】[Lydsy1711月赛]图的价值(NTT+第二类斯特林数)

    题意: 给定\(n\)个点,一个图的价值定义为所有点的度数的\(k\)次方之和. 现在计算所有\(n\)个点的简单无向图的价值之和. 思路: 将式子列出来: \[ \sum_{i=1}^n\sum_{ ...

  7. BZOJ5093 [Lydsy1711月赛]图的价值 【第二类斯特林数 + NTT】

    题目链接 BZOJ5093 题解 点之间是没有区别的,所以我们可以计算出一个点的所有贡献,然后乘上\(n\) 一个点可能向剩余的\(n - 1\)个点连边,那么就有 \[ans = 2^{{n - 1 ...

  8. bzoj5093:图的价值(第二类斯特林数+NTT)

    传送门 首先,题目所求为\[n\times 2^{C_{n-1}^2}\sum_{i=0}^{n-1}C_{n-1}^ii^k\] 即对于每个点\(i\),枚举它的度数,然后计算方案.因为有\(n\) ...

  9. BZOJ5093 图的价值——推式子+第二类斯特林数

    原题链接 题解 题目等价于求这个式子 \[ans=n2^{\frac{(n-1)(n-2)}{2}}\sum\limits_{i=0}^{n-1}\binom{n-1}{i}i^k\] 有这么一个式子 ...

随机推荐

  1. 学习docker on windows (1): 为什么要使用docker

    为什么要用Docker? 如果我们想使用某种pc软件, 那么在互联网上查找并安装软件的流程大致如下图: 那么这就有几个问题要弄清楚: 从哪里获得软件 App Store Linux的包管理 从某些网站 ...

  2. jquary 单选,多选,select 获取和设置值 jquary自定义函数

    <%@ page contentType="text/html; charset=UTF-8"%> <%@ taglib prefix="c" ...

  3. ecshop QQ邮箱发送邮件服务器配置

    ecshop QQ邮箱发送邮件服务器配置 1.邮件服务:采用其他的SMTP服务 2.邮件服务器是否要求加密连接(SSL): 是 此项设置需要php支持openSSL模块 开启方法: a.php.ini ...

  4. unity爬坑记录

    这里记一下平时遇到的unity bug: unity2017最好不要在prefab上面修改它上面的组件参数 最好是拖放到场景之后修改场景内的物体组件参数 完事了apply一下删掉 不这样做的话 可能u ...

  5. EF的Join()和Include()差异性教程

    在EF中表连接常用的有Join()和Include(),两者都可以实现两张表的连接,但又有所不同. 1.Join(),两表不必含有外键关系,需要代码手动指定连接外键相等(具有可拓展性,除了值相等,还能 ...

  6. com.mysql.jdbc.Driver和com.mysql.cj.jdbc.Driver的区别

    概述:com.mysql.jdbc.Driver是mysql-connector-java 5中的,而com.mysql.cj.jdbc.Driver是mysql-connector-java 6中的 ...

  7. Servlet3.0+springmvc5+log4j2正确的开启姿势(WebLookUp)

    前言 java社区占据市场份额比较大的日志组件由log4j 1.×,到logback,再到整合后的升级版 log4j 2.×,有网友测试后据说log4j2的性能最NB.于是开始往自己的springmv ...

  8. Log4j2配置文件详解

    目录[-] 1 系列目录 2 默认配置 3 第一个配置例子 4 复杂一点的配置 4.1 Appender之Syslog配置 4.2 Syslog及Syslog-ng相关配置(Fedora) 5 Log ...

  9. 基于JDK1.8的LinkedList剖析

    之前写了一篇ArrayList,那么今天就写一篇他的姊妹篇,LinkedList. 众所周知,ArrayList底层数据是数组,可以在O(1)的时间内get到数据,但删除和插入就要O(n)时间复杂度. ...

  10. ASP.NET与ASP.NET MVC 的差异、优点及缺点

    众所周知,在微软的编程语言发展历史中,asp.net是不得不提的一个重要的发展阶段,它具有快速开发.层级明确的优点,但最大的缺点,同时也是它逐渐被废弃的原因就是,页面加载的viewstate过于庞大, ...