清华大学生命科学博士就业_已拥有的是全部的生命

清华大学生命科学博士就业_已拥有的是全部的生命不错的组合数学题。同时这也驱使我去看积灰好久的《具体数学》(看了yu大的blog后)。然后看得头秃……得到一个不等式前缀和大于等于取了的个数。所以如果把每个卡的值减一,问题就变成了求一个排列,使得前

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

不错的组合数学题。同时这也驱使我去看积灰好久的《具体数学》(看了yu大的blog后)。然后看得头秃……

得到一个不等式前缀和大于等于取了的个数。所以如果把每个卡的值减一,问题就变成了求一个排列,使得前缀和都非负。

\[\forall i, \mathbf{s.t.} a_1 + a_2 + \dots + a_i \geq 0 \]

显然 \(\sum a_i = 0\)

看样子很难搞。

可以发现,如果把序列循环位移,可能会得到新的方案,那么对每个环进行计算。

但是环可能会贡献多个值,如果这么做,答案就是 \(\sum_{C} f\left(C\right)\),其中 \(C\) 是圆排列, \(f\left(C\right)\) 是断环的方式数,使得前缀和大于等于 \(0\),也等价于找到一个合法的断环方式,此时 \(f\left(C\right)\) 就是使得部分和为 \(0\) 的位置数。

这不就是定义吗?显然一个环的多个贡献给我们的计数造成了麻烦。

考虑转换一下,使环的贡献只能是 \(1\)

如果见过 \(\texttt{Raney}\) 引理,就会发现一个类似的地方:

下面摘自《具体数学》301页 原话:

如果 \(\left< x_1, x_2, \dots , x_m \right>\) 是任何一个其和为 \(+1\) 的整数序列,那么它的循环移位

\[\left< x_1, x_2, \dots , x_m \right>,\left< x_2, \dots ,x_m,x_1 \right>,\dots,\left< x_m, x_1,\dots ,x_{m-1} \right> \]

中恰好有一个满足所有的部分和都是正数。

可以感性理解一下

然后提供了一个例子,就是往卡特兰数计数时,序列最前面加一个 \(1\)。然后容易计数。

这道题的部分和非负,如果在序列前面加个 \(1\),不就是 \(\texttt{Raney}\) 引理了?

我们考虑像这个引理一样,在序列头加一个 \(1\),可以发现,并不是所有地方都能加,例如 \(2,-1,-1\),如果在 \(2\) 后面加 \(1\) 显然是不行的。然后发现加的方案数正好和上面的 \(f\left( C\right)\) 一样——这不是加了跟没加一样?

但是不用担心,我们考虑黑科技,不加 \(1\),改成加 \(-1\)

我们往原序列里插入一个 \({-1}^*\) ,此时问题转换为对圆排列找出一种断环方式,使得前 \(m\) 个的部分和非负,并且元素和为 \(-1\)

易证最后一个必定是 \(-1\),并且用类似方法可以证明一定存在且仅存在一个满足条件的断环方式。(我不会证,逃

由于有标号,有 \(m – n + 1\)\(-1\),于是最后一个 \(-1\) 就有 \(m – n + 1\) 种标号。我们要钦定最后一个 \(-1\)\({-1}^*\),所以答案要除以 \(m – n + 1\)

\(m + 1\) 个元素的圆排列方案数为 \(m!\),于是答案就是 \(\frac{m!}{m – n + 1}\)

复杂度 \(O\left(m\right)\),可以通过此题。

使用快速阶乘可以得到更低的复杂度以及更大的常数。

#include <bits/stdc++.h>

const int mod = 998244353;
typedef long long LL;
int n, m;
int main() {
	std::cin >> n;
	for (int i = 1, t; i <= n; ++i) std::cin >> t, m += t;
	int ans = 1;
	for (int i = 2; i <= m; ++i)
		if (i != m - n + 1)
			ans = (LL) ans * i % mod;
	std::cout << ans << std::endl;
	return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/167479.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月2日 下午2:00
下一篇 2022年8月2日 下午2:00


相关推荐

  • 区分一下驻点和极值点以及最值-一元

    区分一下驻点和极值点以及最值-一元驻点和极值点驻点和极值点的区别 如果函数不可导的话那么他们没有关系如果函数可导的话 那么驻点不一定是极值点 但是极值点一定是驻点这里说明一下就是极值点要不就是不可导点要不就是驻点 如果函数可导的话 那么极值点就是驻点了 但是驻点不一定是极值点比如 x 3 驻点就是导函数为 0 的点 那么 x 3 导函数在 0 0 处就是 0 但是不是极值点如果是最值和极值的关系呢这里表明一下 就是最值一不定是极值 因为如果是在区间断点处就不是极值了 但是如果在区间内部的话就是极值然后求最值的 3 步如图上还有这里的注意就是

    2026年3月19日
    2
  • 拉姆达表达式是什么_拉姆达

    拉姆达表达式是什么_拉姆达Q:最近接触到Stream流式编程遇到了一些错误,故做一次总结复习用。一、λ表达式通常我们会用一个类实现接口,然后构造对象作为参数传入,也可以使用匿名类,用λ表达式可以简化匿名类的编写,用例如下。classWorkerimplementsRunnable{@Overridepublicvoidrun(){…

    2026年1月24日
    5
  • ArcGIS线图层转面图层后,使面图层拥有线图层的属性

    ArcGIS线图层转面图层后,使面图层拥有线图层的属性使用 SpatialJoin 工具如下图所示将线图层和面图层加载进去

    2026年3月16日
    3
  • css实现首行缩进

    css实现首行缩进用 CSS 实现段落首缩进两个字符 应该使用首行缩进 text indent 比如文本块中一般每段前空两个汉字 在这里我们需要了解一种长度单位 em em 是相对长度单位 相对于当前对象 父元素 内文本的字体尺寸 我们中文段落一般每段前空两个汉字 实际上 就是首行缩进了 2em p width 200px text indent 2em em 是相对单位 2em 即现在一个字大小的两倍

    2026年3月20日
    3
  • pycharm激活码20120破解方法

    pycharm激活码20120破解方法,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月15日
    46
  • 香港科技大学计算机专业世界排名_世界顶尖计算机科学家排名

    香港科技大学计算机专业世界排名_世界顶尖计算机科学家排名近日,Guide2Research网站发布了2020年度全球计算机科学和电子领域顶级科学家排名。该排名旨在为学术社区提供更多可见性,让更多人了解计算机科学领域影响力较大的研究贡献。…

    2022年8月30日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号