第一类斯特林数

定义

第一类Stirling数\(s(n,m)\),也可记为\(\begin{bmatrix}n\\m\end{bmatrix}\)。

第一类Stirling分为无符号第一类Stirling数\(s_u(n,m)\)和带符号第一类Stirling数\(s_s(n,m)\)。

他们分别表现为其升阶函数和降阶函数的各项系数,形式如下:

\[x^{n\downarrow}=x\cdot (x-1)\cdot (x-2)\cdots (x-n+1)=\sum_{k=0}^ns_s(n,k)\cdot x^k\\
x^{n\uparrow}=x\cdot (x+1)\cdot (x+2)\cdots(x+n-1)=\sum_{k=0}^ns_u(n,k)\cdot x^k
\]

无符号Stirling数更为常用,表示将\(n\)个不同元素构成\(m\)个圆排列的数目。

有无符号Stirling之间有关系式\(s_s(n,m)=(-1)^{n+m}\cdot s_u(n,m)\)。

递推式

无符号第一类Stirling数

设元素有编号\(1,2,...,n\),则将\(n\)个元素构成\(m\)个圆有两种情况:

①把第\(n\)个元素单独作为一个圆,用前\(n-1\)个元素构成\(m-1\)个圆,方案数\(\begin{bmatrix}n-1\\m-1\end{bmatrix}\)。

②用前\(n-1\)个元素构成\(m\)个圆,把第\(n\)个元素插在前\((n-1)\)个元素任意一个之前,方案数\((n-1)\cdot \begin{bmatrix}n-1\\m\end{bmatrix}\)。

综上:

\[\begin{bmatrix}n\\m\end{bmatrix}=\begin{bmatrix}n-1\\m-1\end{bmatrix}+(n-1)\cdot \begin{bmatrix}n-1\\m\end{bmatrix}
\]

赋初值\(s(0,0)=1\)。

有符号第一类Stirling数

可以从其表示的降阶函数归纳证明:

\[\sum_{k=0}^{n}s_s(n,k)\cdot x^k=x^{n\downarrow}=x^{(n-1)\downarrow}\cdot(x-(n-1))=\sum_{k=0}^{n-1}s_s(n-1,k)\cdot x^{k+1}-(n-1)\cdot\sum_{k=0}^{n-1}s_s(n-1,k)\cdot x^k
\]

依次把\(x^m\)的左右两边的系数提取出来得:

\[s_s(n,m)=s_s(n-1,m-1)-n\cdot s_s(n-1,m-1)
\]

用分治+NTT求第一类Stirling数

以求无符号第一类Stirling数为例:

因为可以表示为升阶函数的各项系数,即:

\[x^{n\uparrow}=x\cdot (x+1)\cdot (x+2)\cdots(x+n-1)=\sum_{k=0}^ns_u(n,k)\cdot x^k
\]

我们可以用分治的思想,每次处理一半的多项式来NTT,时间复杂度\(O(n\log^2n)\)。

代码实现

int rev[N];
void NTT(int *a,int x,int K){
int n=(1<<x);
for(int i=0;i<n;i++)if(i<rev[i])swap(a[i],a[rev[i]]);
for(int i=1;i<n;i<<=1){
int tmp=i<<1,wn=ksm(3,(mod-1)/tmp);
if(K==-1)wn=ksm(wn,mod-2);
for(int j=0;j<n;j+=tmp){
int w=1;
for(int k=0;k<i;k++,w=(LL)w*wn%mod){
int x=a[j+k],y=(LL)w*a[i+j+k]%mod;
a[j+k]=(x+y)%mod;a[i+j+k]=(x-y+mod)%mod;
}
}
}
if(K==-1){
int inv=ksm(n,mod-2);
for(int i=0;i<n;i++)a[i]=(LL)a[i]*inv%mod;
}
}
void Binary(int *a,int l,int r){
if(l==r)return a[0]=l,a[1]=1,void();//有符号赋值a[0]=-l;
int mid=l+r>>1;
int f[N],g[N];
memset(f,0,(r-l+1)<<3),memset(g,0,(r-l+1)<<3);
Binary(f,l,mid),Binary(g,mid+1,r);
int x=ceil(log2(r-l+2));
for(int i=0;i<(1<<x);i++)rev[i]=(rev[i>>1]>>1)|((i&1)<<x-1); NTT(f,x,1),NTT(g,x,1);
for(int i=0;i<(1<<x);i++)a[i]=(LL)f[i]*g[i]%mod;
NTT(a,x,-1);
}

例题

Codeforces 960G Bandit Blues

第二类斯特林数

定义

第二类Stirling数记为\(S(n,m)\)或者\(\begin{Bmatrix}n\\m\end{Bmatrix}\) 。

第二类Stirling数实际上是集合的一个拆分,表示将n个不同的元素拆分成m个集合的方案数。

常常用于解决组合数学中几类放球模型;

描述为:将n个不同的球放入m个无差别的盒子中,要求盒子非空,有几种方案?

由容斥原理可以得到其通项公式:

\[\begin{Bmatrix}n\\m\end{Bmatrix}=\frac 1 {m!}\sum_{i=0}^m(-1)^i\binom mi(m-i)^n
\]

递推式

设元素有编号\(1,2,...,n\),则将\(n\)个元素构成\(m\)个集合有两种情况:

①把第\(n\)个元素单独作为一个集合,用前\(n-1\)个元素构成\(m-1\)个集合,方案数\(\begin{Bmatrix}n-1\\m-1\end{Bmatrix}\)。

②用前\(n-1\)个元素构成\(m\)个集合,把第\(n\)个元素插入任意一个集合之中,方案数\(m\cdot \begin{Bmatrix}n-1\\m\end{Bmatrix}\)。

综上:

\[\begin{Bmatrix}n\\m\end{Bmatrix}=\begin{Bmatrix}n-1\\m-1\end{Bmatrix}+m\cdot \begin{Bmatrix}n-1\\m\end{Bmatrix}
\]

赋初值:\(S(0,0)=1\)。


两类Stirling数之间的关系

\[\sum_{i=0}^nS(n,i)s(i,m)=\sum_{i=0}^ns(n,i)S(i,m)
\]

推论&总结

对原式二项式反演可得

\[m^n=\sum_{i=0}^m\binom mi\begin{Bmatrix}n\\i\end{Bmatrix}i!=\sum_{i=0}^m\begin{Bmatrix}n\\i\end{Bmatrix}m^{i\downarrow}
\]

等价于

\[m^n=\sum_{i=0}^n\binom mi\begin{Bmatrix}n\\i\end{Bmatrix}i!=\sum_{i=0}^n\begin{Bmatrix}n\\i\end{Bmatrix}m^{i\downarrow}
\]

可以用于计算其他式子。

比如:

\[\begin{split}
&\sum_{i=0}^ni^k=\sum_{i=0}^k\begin{Bmatrix}k\\i\end{Bmatrix}i!\binom{n+1}{i+1}\\
&\sum_{i=1}^ni^k\binom ni=\sum_{i=0}^k\begin{Bmatrix}k\\i\end{Bmatrix}i!\binom ni2^{n-i}
\end{split}
\]

例题

【TJOI2018】教科书般的亵渎

Codeforces 932E Team Work


将通项公式再化一下:

\[\begin{Bmatrix}n\\m\end{Bmatrix}=\sum_{i=0}^m\frac{(-1)^i}{i!}\cdot\frac{(m-i)^n}{(m-i)!}
\]

这是一个形如\(\sum_{i=0}^mf(i)*g(m-i)\)的卷积的形式,可以用FFT快速计算。

第一个多项式的第\(i\)项系数为\(\frac {(-1)^i}{i!}\);第二个多项式的第\(i\)项系数为\(\frac {i^n}{i!}\)。

两式相乘,第\(i\)项的系数即为\(S(n,i)\)。

例题

【BZOJ5093】图的价值

其他题目

【TJOI/HEOI2016】求和

斯特林反演

\[\displaystyle f(n)=\sum_{k=0}^n \begin{Bmatrix}n\\k \end{Bmatrix}g(k)
\iff g(n)=\sum_{k=0}^n(-1)^{n-k}\begin {bmatrix} n\\k \end{bmatrix}f(k)
\]

证明斯特林反演

首先,我们需要考虑如何建立上升阶乘幂与下降阶乘幂之间的关系。

结论:

\[x^{n\downarrow}=(-1)^n(-x)^{n\uparrow}\\
x^{n\uparrow}=(-1)^n(-x)^{n\downarrow}
\]

证明:

\[\begin{split}
(-1)^n(-x)^{n\uparrow}&=(-1)^n(-x)(-x+1)\cdots(-x+n-1)\\
&=(-1)^n(-x)(-(x-1))\cdots(-(x-n+1))\\
&=x(x-1)\cdots(x-n+1)\\
&=x^{n\downarrow}
\end{split}
\]

同理可证\(x^{n\uparrow}=(-1)^n(-x)^{n\downarrow}\)。


接下来,我们需要证一个叫反转公式的东西:

还是先给出结论:

\[\sum_{i=m}^n(-1)^{n-i}\begin{bmatrix}n\\i\end{bmatrix}\begin{Bmatrix}i\\m\end{Bmatrix}=[m=n]\\
\sum_{i=m}^n(-1)^{n-i}\begin{Bmatrix}n\\i\end{Bmatrix}\begin{bmatrix}i\\m\end{bmatrix}=[m=n]
\]

证明:

\[\begin{split}
n^m&=\sum_{i=0}^m\begin{Bmatrix}m\\i\end{Bmatrix}n^{i\downarrow}\\
&=\sum_{i=0}^m\begin{Bmatrix}m\\i\end{Bmatrix}(-1)^i(-n)^{i\uparrow}
\end{split}
\]

将\(x^{n\uparrow}=\sum\limits_{k=0}^ns_u(n,k)\cdot x^k​\)带入:

\[\begin{split}
n^m&=\sum_{i=0}^m\begin{Bmatrix}m\\i\end{Bmatrix}(-1)^i\sum_{j=0}^i\begin{bmatrix}i\\j\end{bmatrix}(-n)^j\\
&=\sum_{j=0}^mn^j\sum_{i=j}^m\begin{Bmatrix}m\\i\end{Bmatrix}\begin{bmatrix}i\\j\end{bmatrix}(-1)^{i-j}
\end{split}
\]

即:

\[\sum_{i=j}^m\begin{Bmatrix}m\\i\end{Bmatrix}\begin{bmatrix}i\\j\end{bmatrix}(-1)^{i-j}=[j=m]
\]

这个与上面的式2等价,于是我们就证出了其中一个反转公式。

\[\begin{split}
m^{n\downarrow}&=\sum_{i=0}^n(-1)^{n-i}\begin{bmatrix}n\\i\end{bmatrix}m^i\\
&=\sum_{i=0}^n(-1)^{n-i}\begin{bmatrix}n\\i\end{bmatrix}\sum_{j=0}^i\begin{Bmatrix}i\\j\end{Bmatrix}m^{j\downarrow}\\
&=\sum_{j=0}^nm^{j\downarrow}\sum_{i=j}^n(-1)^{n-i}\begin{bmatrix}n\\i\end{bmatrix}\begin{Bmatrix}i\\j\end{Bmatrix}
\end{split}
\]

即:

\[\sum_{i=j}^n(-1)^{n-i}\begin{bmatrix}n\\i\end{bmatrix}\begin{Bmatrix}i\\j\end{Bmatrix}=[j=n]
\]

由此证出了式1。


然后,我们就可以证明斯特林反演了:

若满足\(g(n)=\sum\limits_{j=0}^n(-1)^{n-j}\begin{bmatrix}n\\j\end{bmatrix}f(j)\),则

\[\begin{split}
f(n)&=\sum_{j=0}^n[j=n]f(j)\\
&=\sum_{j=0}^n\sum_{k=j}^n\begin{Bmatrix}n\\k\end{Bmatrix}\begin{bmatrix}k\\j\end{bmatrix}(-1)^{k-j}f(j)\\
&=\sum_{k=0}^n\begin{Bmatrix}n\\k\end{Bmatrix}\sum_{j=0}^k(-1)^{k-j}\begin{bmatrix}k\\j\end{bmatrix}f(j)\\
&=\sum_{k=0}^n\begin{Bmatrix}n\\k\end{Bmatrix}g(k)
\end{split}
\]

例题

斯特林数&斯特林反演的更多相关文章

  1. CF961G Partitions(第二类斯特林数)

    题目 CF961G 前置 斯特林数\(\Longrightarrow\)斯特林数及反演总结 做法 相信大家能得出一个一眼式:\[Ans=\sum\limits_{i=1}^n w_i\sum\limi ...

  2. [国家集训队] Crash 的文明世界(第二类斯特林数)

    题目 [国家集训队] Crash 的文明世界 前置 斯特林数\(\Longrightarrow\)斯特林数及反演总结 做法 \[\begin{aligned} ans_x&=\sum\limi ...

  3. [HEOI2016/TJOI2016]求和(第二类斯特林数)

    题目 [HEOI2016/TJOI2016]求和 关于斯特林数与反演的更多姿势\(\Longrightarrow\)点这里 做法 \[\begin{aligned}\\ Ans&=\sum\l ...

  4. CF932E Team Work(第二类斯特林数)

    题目 CF932E Team Work 前置:斯特林数\(\Longrightarrow\)点这里 做法 \[\begin{aligned}\\ &\sum\limits_{i=1}^n C_ ...

  5. 【51NOD 1847】奇怪的数学题(莫比乌斯反演,杜教筛,min_25筛,第二类斯特林数)

    [51NOD 1847]奇怪的数学题(莫比乌斯反演,杜教筛,min_25筛,第二类斯特林数) 题面 51NOD \[\sum_{i=1}^n\sum_{j=1}^nsgcd(i,j)^k\] 其中\( ...

  6. 数学杂烩总结(多项式/形式幂级数+FWT+特征多项式+生成函数+斯特林数+二次剩余+单位根反演+置换群)

    数学杂烩总结(多项式/形式幂级数+FWT+特征多项式+生成函数+斯特林数+二次剩余+单位根反演+置换群) 因为不会做目录所以请善用ctrl+F 本来想的是笔记之类的,写着写着就变成了资源整理 一些有的 ...

  7. bzoj5093图的价值:多项式,斯特林数(二项式反演)

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

  8. BZOJ.5093.[Lydsy1711月赛]图的价值(NTT 斯特林数)

    题目链接 对于单独一个点,我们枚举它的度数(有多少条边)来计算它的贡献:\[\sum_{i=0}^{n-1}i^kC_{n-1}^i2^{\frac{(n-2)(n-1)}{2}}\] 每个点是一样的 ...

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

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

随机推荐

  1. 真的,移动端尺寸自适应与dpr无关

    做移动端自适应时可能很多人都对自适应和dpr之间的关系产生疑问,也有一些人会疑虑比如我的自适应方案没有加dpr会不会出问题,针对这些疑问我说一下我的见解. 1. 什么是尺寸自适应 首先标题说的自适应, ...

  2. Ubuntu查看和自动挂载硬盘

    sudo blkid 查看UUID vim /etc/fstab 进行修改 如果 fstab 文件中的命令挂载的硬盘不存在,启动的时候会报错.

  3. linux0.11源码内核——系统调用,int80的实现细节

    linux0.11添加系统调用的步骤 假设添加一个系统调用foo() 1.修改include/linux/sys.h 添加声明 extern int foo(); 同时在sys_call_table数 ...

  4. [CSP-S模拟测试]:折射(DP)

    题目描述 小$Y$十分喜爱光学相关的问题,一天他正在研究折射. 他在平面上放置了$n$个折射装置,希望利用这些装置画出美丽的折线. 折线将从某个装置出发,并且在经过一处装置时可以转向,若经过的装置坐标 ...

  5. [CSP-S模拟测试]:Race(数学+Trie树)

    题目描述 一年一度的运动会开始了.有$N$个选手参赛,第$i$个选手有一个能力值(保证$A[i]$两两不同),比赛一共进行了天.在第$j$天($0\leqslant j\leqslant 2^{m-1 ...

  6. [CSP-S模拟测试]:Miner(欧拉路)

    题目背景 $And\ the\ universe\ said\ you\ are\ the\ daylight \\ And\ the\ universe\ said\ you\ are\ the\ ...

  7. linux设备驱动第二篇:构造和运行模块

      上一篇介绍了Linux驱动的概念,以及linux下设备驱动的基本分类情况及其各个分类的依据和差异,这一篇我们来描述如何写一个类似hello world的简单测试驱动程序.而这个驱动的唯一功能就是输 ...

  8. centos7.4 搭建lnmp

    系统:阿里云 centos7.4 Php:PHP 7.1.13 (cli) Mysql:mysql5.7 Nginx:nginx/1.12.2 一.更新centos7 yum源 cp /etc/yum ...

  9. play framework 在idea简单运行配置(mac为例)

    文章目录 play 最基本的构建 在idea中配置 配置jdk相关 配置play 运行 运行 play 最基本的构建 https://blog.csdn.net/dataiyangu/article/ ...

  10. Mac版-python环境配置(二):编译器pycharm下载安装

    简介 PyCharm是一种Python IDE,带有一整套可以帮助用户在使用Python语言开发时提高其效率的工具,比如调试.语法高亮.Project管理.代码跳转.智能提示.自动完成.单元测试.版本 ...