20251002NOIP模拟赛

T4:

题目大意:

定义一个数组 \(a\) 是良好的,当且仅当可以选择若干个(可以为 0)不交的区间,将他们内部 reverse 之后升序。
给定 \(n\) 和排列 \(a\),对于每个 \(k\),求有多少子序列不包含 \(a_{k}\) 且是良好的。
\(n \le 3 \times 10^3\)

解题思路:

考虑刻画一个良好的数组,发现一定能将其分为若干段,使得段内倒序,段之间正序,且互不相交。
这显然是一一对应的。
f
由于 \(n \le 3000\) 且合法性与相邻的有关,所以考虑 dp。
自然的,设 \(dp_{i,j}\) 表示前 \(i\) 个数,最大值为 \(j\) 的方案数。
转移可以直接用前缀和优化,而且 \(i,j\) 内部可以预处理 \(f_{i,j}\),表示 \(i\) 开头, \(j\) 结尾的递减子序列的方案数。
\(O(n^2 \log n)\)

我们要算每一个 \(x\),求不包含 \(x\) 的方案数,但我们发现枚举完 \(x\) 之后要合并前后缀,但直接做是 \(O(n^3)\) 的。
因为不包含 \(x\) 需要在 \(y \ne x\) 时更新,而这样是不好更新的,所以考虑拿整体减去经过 \(x\) 的方案。

那么我们枚举 \(l,r\) 表示 \(x\) 所在的段内的开头和结尾,那么内部的方案数是 \(f_{l,x} \times f_{x,r}\),而外部的则是 \(pre_{l - 1, a_{r} - 1} \times suf_{r + 1, a_{l} + 1}\)
其中 \(pre\)\(suf\) 分别为做一遍前缀/后缀 \(dp\) 的二维前缀和。

但是这些数看起来都是相互关联的,而 \(pre\)\(suf\) 的结构比较复杂,所以考虑优化一些 \(f_{l,x} \times f_{x,r}\) 之类的东西。
由于 \(n \le 3000\),也就是说我们有枚举两个值的机会,考虑先枚举 \(l\) 试试。

因为 \(x \le r\),所以后面的能影响前面的,而且前面的不影响后面的。
所以我们倒着枚举 \(x\),看一下后面的 \(x\) 作为 \(r\) 时对前面的 \(x\) 有什么影响。

对于后面一个 \(r\) 对于当前点的影响,我们可以发现只有 \(f_{x,r}\) 不确定,但是我们发现 \(f\) 是可以递推的,所以将不同的 \(r\) 赋一个对应的权值,相加即可。
\(O(n^2 \log n)\)

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

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

相关文章

网站怎么做qq微信登陆个人建网站允许吗

Cython不仅仅是一种编程语言。它的起源可以追溯到SAGE数学软件包,它用于提高数学计算性能,例如涉及矩阵的计算。更一般地说,我倾向于将Cython视为SWIG的替代品,为本机代码生成非常好的Python绑定。SWIG是最早和最好之一&#xff0…

自助网站建设技术支持品牌网站分析

python全栈开发笔记第二模块 第四章 :常用模块(第二部分) 一、os 模块的 详解 1、os.getcwd() :得到当前工作目录,即当前python解释器所在目录路径 import os j os.getcwd() # 返回当前pyt…

P10279 [USACO24OPEN] The Winning Gene S题解

题目描述 给定一个长为 \(N\) 的字符串 \(S\),其中 \(1\le N\le 3000\)。对某个数对 \((K,L)\),其中 \(1\le L\le K\le N\),从 \(S\) 中取出所有 \(K\) 长度的子串,取出其所有长度为 \(L\) 的子串,将字典序最小的…

广州电商网站开发公司单页面 网站

简介: 7月8日,中文语言理解权威评测基准CLUE公开了中文小样本学习评测榜单最新结果,阿里云计算平台PAI团队携手达摩院智能对话与服务技术团队,在大模型和无参数限制模型双赛道总成绩第一名,决赛答辩总成绩第一名。 作…

欧亚专线到国内多久网站东莞优化建设

利用示波器统计工具分析有噪声信号之测量统计和余晖图2019-09-24数字示波提供了多种基于统计的工具,除了前文提到的平均和直方图之外,测量参数统计和余晖图,也是非常有用的工具,协助快速获取有用信息。对于示波器测量参数&#xf…

网站制作方案怎么写wordpress微信付款插件

命令stat命令语法stat(选项)(参数)命令描述命令stat用于显示文件的状态信息。stat命令的输出信息比ls命令的输出信息要更详细。命令选项-L:支持符号连接;-f:显示文件系统状态而非文件状态;-t:以简洁方式输出信息&#…

机构类网站有哪些网站建设辶金手指排名十五

博主个人小程序已经上线:【中二少年工具箱】 小程序二维如下: 正文开始 专栏简介专栏初衷 专栏简介 本系列文章由浅入深,从基础知识到实战开发,非常适合入门同学。 零基础读者也能成功由本系列文章入门,但如果您具…

从零搭建雷池WAF:环境配置、安装部署与Web防护实战

从零搭建雷池WAF:环境配置、安装部署与Web防护实战 在Web安全领域,WAF(Web应用防火墙)是抵御SQL注入、XSS、文件上传等攻击的关键防线。雷池(SafeLine)作为一款开源且易用的WAF工具,能有效保护Web服务安全。本文…

如何免费建设网站免费logo设计在线生成器官网

贴一篇源码分析的好文章:https://blog.csdn.net/qq_30905661/article/details/114400417 本质: 一个事务对应一个数据库连接。 通过 this 来调用某个带有 Transactional 注解的方法时,这个注解是失效的,可以看做这个方法&#x…

让别人做网站需要提供什么企业黄页网站源码

前言:当设计师通过photoshop工具设计完设计稿导出psd文件时,我们前端工程师该如何进行切图转换成网页的所需的图片呢,接下来讲讲如何利用photoshop工具快速简洁的切图,因为ps工具用到的行业很多,涉及到的各个行业&…

使用Java将Word文件转换为PNG图片 - 指南

使用Java将Word文件转换为PNG图片 - 指南pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "M…

论文速读记录 | 2025.10

2025.10 | 速读文章纪录目录Horizon Generalization in Reinforcement LearningHIQL: Offline Goal-Conditioned RL with Latent States as ActionsContrastive Preference Learning: Learning from Human Feedback wi…

【Rust GUI开发入门】编写一个本地音乐播放器(15. 记录运行日志) - Jordan

本系列教程对应的代码已开源在 Github zeedle 本篇文章介绍如何将音乐播放器的运行情况持久化记录到日志文件中,这对分析程序意外情况出现的原因很有帮助! 使用最常用的env_logger,将其添加到Cargo.toml中: env_lo…

成都网站建设 3ewordpress简单投稿

在现代社会中,电力是我们生活和工作不可或缺的一部分。大楼宾馆作为城市中繁忙生活的一部分,依赖于可靠的电力供应来支持各种设施和服务,从客房照明到电梯运行,无一不离电。然而,大楼宾馆电力分配系统的稳定性和安全性…

6 种常见 AI 编程协作便捷的方法总结

6 种常见 AI 编程协作便捷的方法总结pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monac…

可以做产品推广的网站flash网站整站下载

目录 1.1 关于版本控制 1.1.1 本地版本控制 1.1.2 集中化的版本控制系统 1.1.3 分布式版本控制系统 1.2 Git简介 1.2.1 Git历史 1.3 安装git 1.3.1 环境说明 1.3.2 Yum安装Git 1.3.3 编译安装 1.4 初次运行 Git 前的配置 1.4.1 配置git 1.4.2 获取帮助 1.5 获取 G…

DeploySharp开源发布:让C#部署深度学习模型更加简单

DeploySharp:面向C#开发者的跨平台模型部署框架 DeploySharp是一款专为C#开发者设计的深度学习模型部署框架,支持OpenVINO和ONNX Runtime推理引擎,兼容YOLOv5-v12全系列模型以及Anomalib等主流模型。该框架采用模块…

光伏电站建设的国家网站湖南网站托管

java之NIO 1 什么是NIO Java NIO (New IO,Non-Blocking IO)是从Java 1.4版本开始引入的一套新的IO API。NIO支持面向缓冲区的、基于通道的IO操作。NIO的三大核心部分:通道(Channel),缓冲区(Buffer), 选择器(Selector),数据总是从…

视频多的网站建设如何建设一个静态网站

什么是柔性数组 什么是柔性数组?柔性数组其实也是动态内存管理部分的内容。这节主要来复习柔性数组的知识点。 当结构体的最后一个成员为数组, 且这个数组的大小未确定时, 我们就称它是柔性数组。 如: struct stu{char name[…

泰康人寿保险官方网站专题学习网站模板

boot读取配置文件1. yml配置文件2. 绑定方式13. 绑定方式23.1 依赖.3.2 boot 中提供的属性装配功能。1. 在某些业务中,需要将类的配置写到配置文件中, 不在代码中写死配置。 2. 所以需要读取配置文件(yaml, properties) 读取到Java Bean中。 3. 本文以oss对象存储配…