前言

在这里首先感谢一下题解区的 FZzzz,本人的题解思路主要是基于他并给出了自己的理解。

如非特殊说明,本题解中的数学符号原则上与题目中一致。

题目分析

需要转化的喵喵题。

我们需要把原问题转化成一个图论计数问题,然后剩下的就很好办了。

好,首先让我们修改一下题目的要求,将不存在的情况设为 \(p_i = 0\),这样就可以使得我们的 \(p_i\) 的值只可能取到自然数集合中连续的一段 \([0,n-1]\) 了。

考虑连边 \((i,p_i)\),我们首先能得到一个十分显然的性质,就是最终连边连出来的图必定没有环,证明显然,考虑偏序关系不允许出现环即可。

但是这个性质不是很强,我们还可以进一步得到相比更强的性质,就是连出来的图必定是一棵树,这个证明考虑 \(p_i\) 的值只会取到 \([0,i-1]\) 而已,又因为不会出现环,故现在此时连出来的是一棵树,并且是以 \(0\) 为根节点的树。

现在让我们观察一下每个节点上 \(h_i\) 的值,不难发现兄弟之间左方的兄弟的 \(h\) 值 \(\le\) 右方的兄弟的 \(h\) 值,且当前节点的 \(h\) 值一定大于他的儿子们。证明显然,考虑如果左方的兄弟大于自己,则自己会被左方的兄弟支配,变成他的儿子,故左右兄弟之间是 \(\le\),考虑如果自己的儿子大于等于自己,那么它必定会成为自己的兄弟甚至是祖先的兄弟,故父亲儿子之间是 \(\gt\)。

让我们定义 \(a_i\) 为 \(i\) 左边第一个的兄弟,让 \(b_i\) 为 \(i\) 最右边的儿子,设 \(c_i=\max\{c_{a_i} , c_{b_i} + 1\}\),则此时 \(c\) 必定是 \(h\) 的构造方案之一(证明考虑兄弟之间的偏序关系和父亲儿子之间的偏序关系),并且对于任意的 \(h\) 我们都有 \(h_i \ge c_i\),于是可以比较 \(c_i\) 与 \(x_i\) 就可以看出 \(p\) 是否合法。

最后,设 \(dp_{i,j,k}\) 为区间 \([i-1,j]\) 形成了一棵树,且 \(c_{b_{i-1}} \le k\) 时,\([i,j]\) 的方案数,时间复杂度 \(\mathcal O(n^4)\)。

代码实现

这里只给出了代码的关键部分,其余部分还恳请读者自行实现。

int n;

int X[MAX_SIZE];
int dp[MAX_SIZE][MAX_SIZE][MAX_SIZE]; void main() {
n = read();
for (int i = 1; i <= n; i++) {
X[i] = read();
}
for (int i = 0; i <= n; i++) {
for (int j = 0; j <= n; j++) {
dp[i + 1][i][j] = 1;
}
}
for (int i = n; i >= 1; --i) {
for (int j = i; j <= n; j++) {
for (int k = 1; k <= n; k++) {
for (int p = i; p <= j; p++) {
int q = min(k, X[p]);
dp[i][j][k] =
mt.add(dp[i][j][k],
mt.mul(dp[i][p - 1][q], dp[p + 1][j][q - 1]));
}
}
}
}
printf("%lld\n", dp[1][n][n]);
return void();
}

题解 ARC104F的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

  10. JSOI2016R3 瞎BB题解

    题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...

随机推荐

  1. 我真的想知道,AI框架跟计算图什么关系?PyTorch如何表达计算图?

    目前主流的深度学习框架都选择使用计算图来抽象神经网络计算表达,通过通用的数据结构(张量)来理解.表达和执行神经网络模型,通过计算图可以把 AI 系统化的问题形象地表示出来. 本节将会以AI概念落地的时 ...

  2. 2021-7-11 Vue的自定义指令简单实例

    获取焦点简单实例,用Vue.directive(ps:指令)定义,命名不要是关键字,用v-加自定义指令名称调用,而内部用钩子函数inserted来实现 <!DOCTYPE html> &l ...

  3. Selenium+2Captcha 自动化+验证码识别实战

    本文深入探讨了使用Selenium库进行网页自动化操作,并结合2Captcha服务实现ReCAPTCHA验证码的破解.内容涵盖Selenium的基础知识.验证码的分类.2Captcha服务的使用,以及 ...

  4. 堆 Heap & 栈 Stack(.Net)【概念解析系列_3】【C# 基础】

    〇.前言 本文主要围绕 .Net 框架中的托管堆(Heap,简称堆)和堆栈(Stack,简称栈)展开. .Net 程序在 CLR(Common Language Runtime 公共语言运行时)上运行 ...

  5. [mysql]定制封装MySQL的docker镜像

    前言 基于MySQL的原版镜像做一些个性化配置修改,封装/etc/my.cnf文件到镜像中,并且支持通过环境变量修改innodb_buffer_pool_size.server_id以及自动配置inn ...

  6. debian11安装配置记录

    安装 软件包默认是桌面环境 + gnome + 标准安装.如果做服务器,建议标准安装 + ssh server 设置静态ip cd /etc/network/interfaces.d vi ifcfg ...

  7. 开机自动打开termux以及启动termux的服务

    ps:因为我们的服务是安装在平板上面的termux,客户不想维护麻烦,如果平板重启之后还需要手动启动ternux,还要开启命令启动服务,这样比较麻烦,所以研究如下操作 1.安装macroDroid 直 ...

  8. 设置服务账号Service Accounts(sa)的token不挂载到pod

    目录 一.系统环境 二.前言 三.Service Accounts(sa)简介 四.在pod里设置sa的token不挂载到pod 五.在sa里设置sa对应的token不挂载到pod上 六.总结 一.系 ...

  9. Mybatis插件功能

    1 插件的作用 在Mybatis执行SQL的生命周期中,会使用插件进行埋点,主要包括Executor.StatementHandler.ParameterHandler和ResultSetHandle ...

  10. 使用 Rancher 安装 K8s 集群

    舞台环境 Ubuntu 22.04.2 LTS Docker 24.0.2 2GB RAM或者更多 CPU 2核心或者更多 Rancher 2.6.9 测试环境中,我准备了两台 Ubuntu 服务器, ...