【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. 如何在Python中从零开始实现随机森林

    欢迎大家前往云+社区,获取更多腾讯海量技术实践干货哦~ 决策树可能会受到高度变异的影响,使得结果对所使用的特定测试数据而言变得脆弱. 根据您的测试数据样本构建多个模型(称为套袋)可以减少这种差异,但是 ...

  2. TinyMce 使用初探

    https://www.cnblogs.com/nkxyf/p/3883586.html 参考:http://www.tinymce.com/    官网 http://www.tinymce.com ...

  3. git 版本控制的简单应用

    一.通过 honebrew 安装git , 教程参考:http://brew.sh/index_zh-cn.html 也可对比参考:http://book.51cto.com/art/201107/2 ...

  4. Mysql查询某字段值重复的数据

    查询user表中,user_name字段值重复的数据及重复次数 select user_name,count(*) as count from user group by user_name havi ...

  5. Linux系统内存占用90%以上——解决方法

    Linux系统内存占用90%以上--解决方法   首先要明确一个问题:Linux系统内存占用90%以上,是否属于正常范围?网上有详细的解释,这属于正常现象~~~    www.2cto.com   L ...

  6. ajax请求中contentType与dataType区别

    contentType: 告诉服务器,我要发什么类型的数据,默认值: "application/x-www-form-urlencoded". dataType:告诉服务器,我要想 ...

  7. OKL4虚拟化技术跟踪

    这篇博客准备介绍OKL4的研究进展,本文的内容主要根据我个人阅读<OKL4_LongPaper_2010_HW_VM>这篇文章之后的理解,我也根据这篇论文的内容做了一些实验,奈何此论文涉及 ...

  8. Log4j2配置文件详解

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

  9. 判断json是否包含了每个键 PHP

    (1)可以用array_key_exists去判断object对象或array数组中是否含有某个键: (2)不可以用isset去判断判断object对象或array数组中是否含有某个键 $decode ...

  10. 开发工具类API调用的代码示例合集:六位图片验证码生成、四位图片验证码生成、简单验证码识别等

    以下示例代码适用于 www.apishop.net 网站下的API,使用本文提及的接口调用代码示例前,您需要先申请相应的API服务. 六位图片验证码生成:包括纯数字.小写字母.大写字母.大小写混合.数 ...