atcoder ABC385 部分题解

news/2025/1/2 13:31:37/文章来源:https://www.cnblogs.com/-cchen-/p/18643269

G - Counting Buildings

简要题义

一个排列的 \(L(P)\)\(\sum_{i=1}^n [premax(i)=P_i]\),即前缀最大值为自身的位置数,\(R(P)\) 同理为后缀最大值。

有多少个排列使得 \(L(P)-R(P)=k\)

题解

假设 \(n,k\) 是同阶的。

我们从 \(n\)\(1\) 依次插入数,考虑朴素的 DP:设 \(f_{i,k}\) 表示当前填了 \([n-i+1,n]\) 这些数,\(L-R=k\) 的方案数。当插入一个数时,将其放在首位 \(L\) 一定增加 \(1\) ,放在末尾,\(R\) 一定增加 \(1\) ,其余位置,\(L,R\) 不变,有转移:

\[f_{i,k}=f_{i-1,k-1}+f_{i-1,k+1}+(i-2) \cdot f_{i-1,k} \]

\(F_i=\sum [x^k] f_{i,k}\),我们最终求 \([x^k] F_n\)

该状态转移可以写成多项式形式,即 \(F_i=(x+(i-2)+\frac{1}{x}) F_{i-1}\) ,那 \(F_n=\prod_{i=2}^n (x+(i-2)+\frac{1}{x})=\prod_{i=0}^{n-2} (x+i+\frac{1}{x})\)

负系数不太好维护,改成 \([x^k] F_n=[x^k]\prod_{i=0}^{n-2} (x+i+\frac{1}{x}) = [x^{k+n-1}] \prod_{i=0}^{n-2} (x^2+ix+1)\)

两个幂次为 \(n\) 的多项式乘法可以在 \(O(nlogn)\) 的复杂度下完成。运用启发式合并的思想,我们每次找到当前次数最小的两个多项式做乘法,每个多项式最多被计算 \(O(logn)\) 次,总的复杂度为 \(O(nlog^2n)\)

当然,可以使用分治模拟启发式合并的过程,保证每一个搜索层下,现有多项式的次数都尽可能的平均,也就是模拟了启发式合并。

多项式乘法用 NTT 。

参考代码(分治做法)

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

X00119-SDN下移动边缘计算市场中的智能动态数据卸载python实现

软件定义网络(SDN)和移动边缘计算(MEC),能够动态管理和满足终端用户的计算需求,已经成为5G网络的关键使能技术。此项目研究了在多MEC服务器和多终端用户环境下,终端用户选择MEC服务器及其数据卸载的联合问题,以及MEC服务器的最优定价问题。SDN技术提供的灵活性和可编程…

【分布式框架】XXL-RPC v1.8.0

一、Release Notes 1、【重构】针对 “Core/核心模块” 进行架构模块化重构,拆分 Provider、Invoker、Serializer、Remoting、Registry 和 Boot 等六个核心模块:Provider:定位为服务提供者,提供RPC服务端能力,包括RCP/HTTP Server、业务Service扫描维护、服务执行等能力。…

解决U盘不能传输大文件的问题

将“文件系统”改成“NTFS”,默认一般是FAT32,然后点击格式化即可。注意U盘不要有重要数据避免数据丢失

网站打开不稳定,如何排查和解决?

网站打开不稳定可能由多种因素引起,包括服务器性能、网络问题、代码错误等。以下是详细的排查步骤和解决方案,帮助您找到并解决问题:检查服务器性能:CPU和内存使用情况:使用 top 或 htop 命令查看服务器的CPU和内存使用情况。如果资源占用过高,可能导致网站响应缓慢或无法…

服务器配置显示异常,带宽和内存与预期不符

关于您提到的服务器配置显示异常的问题,我们非常理解您的困惑。根据您的描述,您发现服务器的带宽从原来的8M变成了4M,内存也从4G变成了2G。为了帮助您更好地解决这个问题,我们需要进行以下几个步骤的排查和确认。 首先,请确保您登录的是正确的服务器账号和密码。有时由于多…

如何处理服务器端口888突然无法访问的问题

关于您提到的服务器端口888突然无法访问的问题,我们非常理解您的困扰。根据您的描述,宝塔面板因存在致命漏洞,为了保障数据安全,我们在安全组中暂时阻止了888端口。以下是详细的解决方案和建议,帮助您尽快恢复正常访问。 首先,强烈建议您立即更新宝塔面板的安全补丁。这是…

如何解决服务器空间扩容后FTP无法上传文件及宝塔面板容量未更新的问题?

您好,根据您的描述,在升级服务器空间容量后,您遇到了FTP无法上传文件以及宝塔面板显示的容量未更新的问题。以下是详细的解决方案和建议:确认磁盘扩容是否成功:首先,确保服务器提供商确实已经完成了磁盘扩容操作。可以通过服务商的管理控制台或联系技术支持确认扩容状态。…

如何解决云服务器网络访问异常的问题?

您好,根据您的描述,云服务器出现了网络访问异常的情况,严重影响了业务的正常运行。以下是详细的分析和解决方案:确认网络连接状态:使用命令行工具(如ping、traceroute)测试服务器与外部网络的连通性,确定是否存在网络中断或延迟过高的问题。 检查服务器的本地网络配置(…

如何正确开启服务器上的某个端口?

在服务器上正确开启某个特定端口(如465端口)是一项常见但又容易出错的任务。为了确保端口能够顺利打开并正常工作,以下是详细的步骤指南和注意事项:理解端口作用:首先明确要开启的端口用途。例如,465端口主要用于SMTPS协议,即通过SSL加密发送电子邮件。确保该端口确实是…

如何优化数据库查询速度,特别是使用多个CONTAINS条件时?

您好,当您在数据库查询中使用多个CONTAINS条件时,查询速度可能会显著下降。为了优化这种查询,您可以采取以下几种方法: 首先,确保数据库中有适当的索引。索引是提高查询速度的关键。对于包含全文搜索条件的查询,创建全文索引是非常有效的。以MySQL为例,您可以使用以下命…

如何找回宝塔面板的登录网址?

如果您忘记了宝塔面板的登录网址,可以通过以下步骤来找回或重新设置:检查服务器IP地址: 宝塔面板的默认访问地址通常是 http://<服务器IP>:8888 或者 https://<服务器IP>:8888。您可以登录到您的服务器提供商控制台,找到您服务器的公网IP地址。查看宝塔面板安装…

如何解决宝塔面板无法打开的问题?

当您遇到宝塔面板无法打开的情况时,可能是由多种原因引起的。以下是一些常见的排查步骤和解决方案,帮助您快速恢复宝塔面板的正常访问:检查服务器状态: 首先确认服务器是否正常运行。您可以登录到服务器提供商的控制台,查看服务器的状态。如果服务器处于关机或重启状态,请…