3.8 CW 模拟赛 T2. 沉默乐团

news/2025/3/9 19:49:13/文章来源:https://www.cnblogs.com/YzaCsp/p/18761243

前言

\(\rm{T1}\) 没想到并查集实际上是糖了
但是差点完全想不到正解实际上是更糖的

其实我们只要在找性质的时候发现其不相关性即可
具体的, 只要你前面位置该占得占了即可
但是害怕害怕, 差点信心碎了满地, 害怕害怕

然后一个警示就是策略太复杂直接丢掉肯定假, 也就是换思路的必要性吧
从这上面看出来自己推确实好方法, 所以也没啥问题吧, 就是性质太复杂考虑换的事情

听讲听讲听讲听讲听讲
问问问问问问问问问问
推推推推推推推推推推

每日 \(\rm{C}\) 的时间必须要抽出来, 长下课就听音乐看 \(\rm{C}\) 得了, 一是可以休息, 二来也培养第一步找性质的能力
主要是本能不够, 找到的性质全他妈屁用没有, 练一下应该就好了

写了这么多, 还是先把这个题看一下

思路

不难发现只需要考虑不交的真前缀和真后缀之和不等

不妨设真前缀的和组成的集合为 \(\mathbb{P} = \{\textrm{pre}_1, \textrm{pre}_2, \textrm{pre}_3, \cdots, \textrm{pre}_{n - 1}\}\) , 对应的设真后缀的和组成的集合为 \(\mathbb{S} = \{\textrm{suf}_n, \textrm{suf}_{n - 1}, \textrm{suf}_{n - 2}, \cdots, \textrm{suf}_2\}\)
显然的, \(\mathbb{P}\), \(\mathbb{S}\) 中是单调递增的

如何判断这两个集合不重
不难发现因为单调性, 可以双指针维护

发现暴力的瓶颈其实在于没能在处理同时判定合法性, 以及没有利用到不相关性
考虑在 \(\rm{dp}\) 过程中就确保合法性
\(f_{l, r, k}\) 表示 \(\mathbb{P}\) 集合放到了第 \(l\) 个, \(\mathbb{S}\) 集合放到了第 \(r\) 个, 现在 \(\textrm{pre}_l - \textrm{suf}_{n - r + 1}\)\(k\) 的方案数

然后只要当前 \(k = 0\) 了别想活着, \(l + r \leq n\) 是必须的
只要 \(k < 0\) , 当前就更新 \(r\) , 否则更新 \(l\)

复杂度在 \(\mathcal{O} (n^2m^2)\) , 可以通过前缀和优化做到 \(\mathcal{O} (n^2 m)\)

总结

这个真不太好想

\(\rm{dp}\) 题往往要找到

  • 前后的无后效性\((\)不相关性\()\)
  • 在处理同时判定合法性

一类计数 \(\rm{dp}\) 同时保证合法性的问题

\(\rm{dp}\) 刷表不好优化, 转化成递推之后再优化

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

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

相关文章

20242802 2024-2025-2 《网络攻防实践》第二周作业

20242802 2024-2025-2 《网络攻防实践》第二周作业 目录 目录20242802 2024-2025-2 《网络攻防实践》第二周作业1. 实验要求2. 实验相关知识点nmap工具使用3. 实验详细过程3.1 从www.besti.edu.cn、baidu.com、sina.com.cn中选择一个DNS域名进行查询,获取如下信息:3.2尝试获取…

UE5之瞄准视角的俯仰偏移

1.创建瞄准姿势 复制瞄准动画,删除其中多余的帧,只保留瞄准的一帧,将其创建为一个单帧动画。然后将其复制成三份,分别用于表示瞄准三个姿势的up,middle,down。 将middle姿势动画的Additive动画类型修改为网格体空间,因为我们需要在网格空间创建叠加动画。基础姿势修改为…

2K star!三分钟搭建企业级后台系统,这款开源Java框架绝了!

"LikeAdmin Java是基于Spring Boot + Mybatis Plus + Vue 3的快速开发平台,内置RBAC权限管理、工作流引擎、数据可视化、三方登录等核心模块,助力开发者快速构建企业级中后台管理系统"2K star!三分钟搭建企业级后台系统,这款开源Java框架绝了!"LikeAdmin J…

震惊!C++程序真的从main开始吗?99%的程序员都答错了

嘿,朋友们好啊!我是小康。今天咱们来聊一个看似简单,但实际上99%的C++程序员都答错的问题:C++程序真的是从main函数开始执行的吗? 如果你毫不犹豫地回答"是",那恭喜你,你和大多数人一样——掉进了C++的第一个陷阱!别担心,等你看完这篇文章,你就能成为那个与…

11套!量产15W~1000W开关电源电路全套方案资料合集!

本系列小编给大家带来了15W到1000W完整量产版开关电源全系列,全套资料分期给大家分享。每套资料都包含详细的原理图,PCB图,变压器图纸,共模电感图纸,磁环图纸!点击下方链接获取! 15W开关电源方案👆👆👆(点击下载) 25W开关电源方案👆👆👆(点击下载) 30W开…

【每日一题】20250309

我所渴望的,不过是过上一种发自本心的生活,为什么竟会如此困难?【每日一题】已知 \(\odot C\) 过点 \(P(1,2)\),与 \(y\) 轴相交于点 \(Q(0,6)\).若过点 \(Q\) 作 \(\odot C\) 的切线 \(l\),其切线 \(l\) 与 \(x\) 轴平行,则 \(l\) 的方程为_________,\(\odot C\) 的标…

FastAPI Cookie 和 Header 参数完全指南:从基础到高级实战

title: FastAPI Cookie 和 Header 参数完全指南:从基础到高级实战 🚀 date: 2025/3/9 updated: 2025/3/9 author: cmdragon excerpt: 本教程深入探讨 FastAPI 中 Cookie 和 Header 参数的读取与设置,涵盖从基础操作到高级用法。通过详细的代码示例、课后测验和常见错误解…

vim按f5运行代码配置

使vim能够像vscode一样按f5运行代码 效果图let g:last_terminal_buf = -1 " 用于存储上一个终端缓冲区编号 function! RunCurrentFile() " 如果存在上次的终端缓冲区,则删除它 if g:last_terminal_buf != -1 && bufexists(g:last_terminal_buf) silent exec…

DeepSeek + Xmind,1分钟自动把pdf/word文档转成思维导图

DeepSeek加Xmind,1分钟把PDF、Word文档转成思维导图!步骤超简单:第一步:打开DeepSeek,点击“深度思考”,上传你的文档。第二步:告诉DeepSeek“帮我转成思维导图,输出Markdown格式”。第三步:复制代码, 保存文件到桌面文本文件中,修改文件后缀为“.md”。第四步:打开…

Windows平台调试器原理与编写05.内存断点

https://www.bpsend.net/thread-274-1-3.html 内存断点访问断点 写入断点内存写入断点简介:当被调试进程访问,读或写指定内存的时候,程序能够断下来。 思考1:要想将一段内存设为内存断点,最终的目的是让其能够抛异常。调试器是基于异常的一个程序。应该如何实现呢?可以通…

Redis--Lesson01--NoSQL简史

单击MySQL的演进 单机MySQL 在早期互联网时代,也就是90年代以前,一个基本的互联网的访问量不会太大,可以说很多国家和地区都还没有配备互联网,所以在这种情况下的互联网格局使用的数据存储格式就是简单的单机模式,即使用一个数据库的如MySQL库就可以满足日常的数据读写 如…

Excel的快捷键

1、填充序号1~1000(删除后,序号会自动更新) (1)首先在左上角的位置框中输入A1:A1000,然后按Enter回车健,即可选中A1到A1000的单元格。(2)然后在函数框中输入=ROW(),按Ctrl + Enter即可,即可填充1-1000。 本文来自博客园,作者:业余砖家,转载请注明原文链接:http…