[ARC121E] Directed Tree 题解

news/2024/9/25 11:03:45

简单容斥题。

思路

题面的条件相当于一个位置上填的点不能是自己的祖先。

发现直接做并不好做。

考虑容斥。

我们想要求出 \(f_i\) 为至少有 \(i\) 个不合法位置的方案数。

那么答案为:

\[\sum_{i=0}^n f_i(-1)^i \]

如何求解。

\(f_{i,j}\)\(i\) 子树下有 \(j\) 个不合法位置的方案数。

第一种转移是普通背包合并。

\[f_{i,j}=\sum_{k=0}f_{s,k}\times f_{i,j-k} \]

第二种转移则是此时子树的根填到子树下的一个位置,相当于多了一个不合法位置。

\[f_{i,j}=f_{i,j}+f_{i,j-1}\times (siz_i-j) \]

最后在令 \(f_{1,i}=f_{1,i}\times (n-i)!\),表示其它的点可以随便摆放。

时间复杂度:\(O(n)\)

Code

#include <bits/stdc++.h>
using namespace std;const int mod = 998244353;#define int long longint n, ans;
int s[2020], p[2020];
int g[2020], v[2020];
int f[2020][2020];
vector<int> to[2020];inline void dfs(int x) {s[x] = f[x][0] = 1;for (auto i : to[x])if (i != p[x]) {dfs(i);fill(g, g + s[x] + s[i] + 1, 0);for (int j = 0; j <= s[x]; j++)for (int k = 0; k <= s[i]; k++)(g[j + k] += f[x][j] * f[i][k]) %= mod;copy(g, g + s[x] + s[i] + 1, f[x]);s[x] += s[i];}for (int i = s[x]; i >= 1; i--)(f[x][i] += f[x][i - 1] * (s[x] - i)) %= mod;
}signed main() {cin >> n;for (int i = 2; i <= n; i++) cin >> p[i];for (int i = 2; i <= n; i++) to[p[i]].push_back(i);dfs(1);v[0] = 1;for (int i = 1; i <= n; i++) v[i] = v[i - 1] * i % mod;for (int i = 0; i <= n; i++) {(ans += v[n - i] * f[1][i] * (i & 1 ? -1 : 1)) %= mod;}cout << (ans + mod) % mod << "\n";
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/64515.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

查看exe启动命令和参数

wmic process where caption="qq.exe" get caption,commandline /value #qq.exe可以更换为任何正在运行的进程

Windows 11 version 23H2 中文版、英文版 (x64、ARM64) 下载 (updated Sep 2024)

Windows 11 version 23H2 中文版、英文版 (x64、ARM64) 下载 (updated Sep 2024)Windows 11 version 23H2 中文版、英文版 (x64、ARM64) 下载 (updated Sep 2024) Windows 11, version 23H2,企业版 arm64 x64 请访问原文链接:https://sysin.org/blog/windows-11/,查看最新版…

【YashanDB知识库】YAS-04110 invalid variant name

本文转自YashanDB官网,具体内容请见https://www.yashandb.com/newsinfo/7369202.html?templateId=1718516 【标题】错误码处理 【问题分类】查询语句报错 【关键字】YAS-04110 【问题描述】执行特定sql时,遇到相应报错 【问题原因分析】字段中含有保留字,应使用双引号包裹字…

章14——Hashtable

键和值为NULL时会抛出空指针异常。KEY重复且无NULL时同样会替换,和HashMap是一样的。按照2倍+1的规律去扩容与HASHMAP对比PROPERTIES,也是MAP接口的实现类,是Hashtable的子类 .properties 文件通常是用于数据库的配置文件,储存数据库的用户名密码等东西 详细可见博客园博客…

mac安装allure成功后pycharm虚拟环境allure不可用

mac安装allure成功pycharm虚拟环境cmd提示zsh: command not found: allure mac查看安装成功在虚拟环境查看失败确认虚拟环境变量 如果 Allure 仍然不可用,检查虚拟环境中的 PATH 环境变量是否包含了 Allure CLI 的路径。在虚拟环境中,你可以运行以下命令来查看 PATH: echo $…

如何删除 WPS 在图片文件属性中添加的“属性修改”选项卡

近期发现 WPS 2023 这一个非常恼人的特性,在图片文件的属性窗口里面乱加第三方选项卡。同事的电脑安装了这个版本,就让同事从注册表试了一下。还好金山他们藏的不是很深,借助 GPT 很快也就找到了。这里再用鄙人自己的虚拟机演示一遍。HKEY_CLASSES_ROOT\*\shellex\PropertyS…

POST请求的艺术:如何有效使用POST方法

在HTTP协议中,POST方法是一种用于向服务器提交数据的请求方式。与GET请求不同,POST请求将数据包含在请求体(request body)中,而不是URL中。这使得POST请求更适合传输大量数据和敏感信息。本文将探讨如何有效使用POST方法,以及它在现代Web开发中的应用。POST请求的基本概念…

Springboot中动态管理定时任务

引言 基于cron表达式的定时任务实现,因为cron表达式对于每个任务不确定,所以使用线程池来动态的创建和销毁定时任务 依赖 因为使用的spring自带的调度功能,所以没有额外的依赖,我的项目版本为: 使用 首先需要定义一个线程池,使用@configuration 注解配置 import org.spr…