Description

题库链接

一个带标号的图的价值定义为每个点度数的 \(k\) 次方的和。给定 \(n\) 和 \(k\) ,请计算所有 \(n\) 个点的带标号的简单无向图的价值之和。对 \(998244353\) 取模。

\(1\leq n\leq 10^9,1\leq k\leq 200000\)

Solution

单独考虑每个点连边情况,容易发现答案就是

\[n\cdot 2^{n-1\choose 2}\sum_{i=0}^{n-1}{n-1\choose i}i^k\]

其中 \(i\) 枚举的是某一个点的度数, \(2^{n-1\choose 2}\) 为其它的 \(n-1\) 个点构成的简单无向图个数。

考虑如何求

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

注意到第二类斯特林数有这样的一个性质:

\[n^k=\sum_{i=0}^nS(k,i){n\choose i}i!\]

可以用含义证明。
左式能够表示 \(k\) 个有区别的球放在 \(n\) 个有区别的盒子中的方案数。
右边则表示先从 \(n\) 个盒子内选出 \(i\) 个放球的盒子。再用斯特林数求出放球的方案后乘上 \(i!\) 表示有序。

带回原式

\[\begin{aligned}&\sum_{i=0}^{n-1}{n-1\choose i}\sum_{j=0}^iS(k,j){i\choose j}j!\\=&\sum_{j=0}^{n-1}S(k,j)(j!)\sum_{i=j}^{n-1}{n-1\choose i}{i\choose j}\end{aligned}\]

容易发现

\[\sum_{i=j}^{n-1}{n-1\choose i}{i\choose j}\]

的含义就是先在 \(n-1\) 个球中选出 \(i\) 个,再在 \(i\) 个球中选出 \(j\) 个。

我们用含义相同的式子来代替它:

\[\sum_{i=j}^{n-1}{n-1\choose i}{i\choose j}={n-1\choose j}\cdot 2^{n-1-j}\]

那么

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

那么不妨用 \(\text{NTT}\) 求出 \(S(k,j),j\in[0,n)\) ,并预处理出其它东西就可以直接算了。

值得注意的是由于 \(n\gg k\) 但不过 \(S(k,j)=0,k<j\) 。所以斯特林数只要处理到 \(k\) 就好了。

Code

#include <bits/stdc++.h>
using namespace std;
const int N = 200000*4, yzh = 998244353; int fac[N+5], ifac[N+5], C[N+5];
int n, k;
int a[N+5], b[N+5], R[N+5], len, L; int quick_pow(int a, int b) {
int ans = 1;
while (b) {
if (b&1) ans = 1ll*ans*a%yzh;
b >>= 1, a = 1ll*a*a%yzh;
}
return ans;
}
void NTT(int *A, int o) {
for (int i = 0; i < len; i++) if (i < R[i]) swap(A[i], A[R[i]]);
for (int i = 1; i < len; i <<= 1) {
int gn = quick_pow(3, (yzh-1)/(i<<1)), x, y;
if (o == -1) gn = quick_pow(gn, yzh-2);
for (int j = 0; j < len; j += (i<<1)) {
int g = 1;
for (int k = 0; k < i; k++, g = 1ll*g*gn%yzh) {
x = A[j+k], y = 1ll*g*A[j+k+i]%yzh;
A[j+k] = (x+y)%yzh, A[j+k+i] = (x-y)%yzh;
}
}
}
if (o == -1)
for (int i = 0, inv = quick_pow(len, yzh-2); i < len; i++) A[i] = 1ll*A[i]*inv%yzh;
}
void work() {
scanf("%d%d", &n, &k); fac[0] = ifac[0] = ifac[1] = C[0] = 1;
for (int i = 2; i <= k; i++) ifac[i] = -1ll*yzh/i*ifac[yzh%i]%yzh;
for (int i = 1; i <= k; i++) C[i] = 1ll*C[i-1]*ifac[i]%yzh*(n-i)%yzh;
for (int i = 1; i <= k; i++)
fac[i] = 1ll*i*fac[i-1]%yzh, ifac[i] = 1ll*ifac[i]*ifac[i-1]%yzh;
for (int i = 0; i <= k; i++) if (i&1) a[i] = -ifac[i]; else a[i] = ifac[i];
for (int i = 0; i <= k; i++) b[i] = 1ll*quick_pow(i, k)*ifac[i]%yzh;
for (len = 1; len <= (k<<1); len <<= 1) ++L;
for (int i = 0; i < len; i++) R[i] = (R[i>>1]>>1)|((i&1)<<(L-1));
NTT(a, 1), NTT(b, 1);
for (int i = 0; i < len; i++) a[i] = 1ll*a[i]*b[i]%yzh;
NTT(a, -1);
int ans = 0;
for (int i = 0; i <= min(n-1, k); i++)
(ans += 1ll*a[i]*fac[i]%yzh*quick_pow(2, n-1-i)%yzh*C[i]%yzh) %= yzh;
ans = 1ll*ans*n%yzh*quick_pow(2, 1ll*(n-1)*(n-2)/2%(yzh-1))%yzh;
printf("%d\n", (ans+yzh)%yzh);
}
int main() {work(); return 0; }

[BZOJ 5093]图的价值的更多相关文章

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

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

  2. 解题:BZOJ 5093 图的价值

    题面 显然只需要考虑一个点(再乘n),那么枚举这个点的度数,另外的$\frac{(n-1)(n-2)}{2}$条边是随意连的,而这个点连出去的边又和其余$n-1$个点产生组合,所以答案就是 $n*\f ...

  3. BZOJ 5093: [Lydsy1711月赛]图的价值

    第二类斯特林数模版题 需要一些组合数的小$ trick$ upd:这里更新了本题巧妙的$ O(k)$做法,虽然常数很大就是了 传送门:here 题意:求所有$ n$个节点的无重边自环图的价值和,定义一 ...

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

    [Lydsy1711月赛]图的价值 Time Limit: 30 Sec  Memory Limit: 256 MBSubmit: 245  Solved: 128[Submit][Status][D ...

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

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

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

    [BZOJ5093]图的价值(第二类斯特林数,组合数学,NTT) 题面 BZOJ 题解 单独考虑每一个点的贡献: 因为不知道它连了几条边,所以枚举一下 \[\sum_{i=0}^{n-1}C_{n-1 ...

  7. [CF932E]Team Work & [BZOJ5093]图的价值

    CF题面 题意:求\(\sum_{i=0}^{n}\binom{n}{i}i^k\) \(n\le10^9,k\le5000\) 模\(10^9+7\) BZOJ题面 题意:求\(n*2^{\frac ...

  8. [BZOJ5093]图的价值(NTT+第二类Stirling数)

    5093: [Lydsy1711月赛]图的价值 Time Limit: 30 Sec  Memory Limit: 256 MBSubmit: 250  Solved: 130[Submit][Sta ...

  9. BZOJ5093图的价值(斯特林数)

    题目描述 “简单无向图”是指无重边.无自环的无向图(不一定连通). 一个带标号的图的价值定义为每个点度数的k次方的和. 给定n和k,请计算所有n个点的带标号的简单无向图的价值之和. 因为答案很大,请对 ...

随机推荐

  1. 算法题丨Remove Duplicates from Sorted Array II

    描述 Follow up for "Remove Duplicates": What if duplicates are allowed at most twice? 示例 Giv ...

  2. 20145237 《Java程序设计》第三周学习总结

    20145237 <Java程序设计>第3周学习总结 教材学习内容总结 第四章主要讲了Java基本类型中的类类型,如何定义类.构造函数.使用标准类.基本类型打包器.数组复制.字符串等内容查 ...

  3. iOS 11 导航栏 item 偏移问题 和 Swift 下 UIButton 设置 title、image 显示问题

    html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,bi ...

  4. Python设计TFTP客户端

    #coding=utf-8 from socket import * from threading import Thread import struct def recvData(fileName, ...

  5. Spring Cache扩展:注解失效时间+主动刷新缓存(二)

    *:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...

  6. MSIL实用指南-生成if...else...语句

    if...else...语句是非常重要的选择语句,它的生成一般需要ILGenerator的DefineLabel方法和MarkLabel方法,以及Brtrue_S和Br_S指令. 一.DefineLa ...

  7. Nginx原理和配置总结

    一:前言 Nginx是一款优秀的HTTP服务器和反向代理服务器,除却网上说的效率高之类的优点,个人的切身体会是Nginx配置确实简单而且还好理解,和redis差不多,比rabbitmq好理解太多了: ...

  8. SpringCloud应用入库后乱码问题

    一.现象 1.请求 2.入库后 二.解决过程 1.配置application.properties 2.代码配置 3.数据库(关键!!) 3.请求 三.验证过程 1.win10 - 本地验证通过 2. ...

  9. angular2 学习笔记 ( animation 动画 )

    refer : https://angular.io/guide/animations https://github.com/angular/angular/blob/master/packages/ ...

  10. 新概念英语(1-13)A new dress

    What colour is Anna's hat? A:What colour is your new dress? B:It's green.Come upstairs and see it. A ...