2025.01.07 杂题记录

news/2025/1/8 6:59:51/文章来源:https://www.cnblogs.com/dccy/p/18658842

2025.01.07 杂题记录

今天是好题选讲,顺便做了一些别的题目。

P3380 【模板】树套树

好,我终于搞明白树套树是怎么回事了,以前一直没做大概是因为平衡树好不太熟悉。

题目大意就是把普通平衡树的各种操作放在序列上,加上区间的限制。

树套树最普遍的做法就是线段树套平衡树。

考虑对线段树上的每一个节点都开一个平衡树,讲到这大概就会做了。

做法1:线段树以位置为索引,在平衡树中存放值。这样的做法,对于查询第 k 大则需要二分答案,时间复杂度是 \(O(n\log^3 n)\),空间复杂度是 \(O(n\log n)\),可能会被卡。

做法2:这是题解区的又一个线段树套平衡树的做法,我实现了这种做法。考虑离散化后,在线段树上以值为索引,往平衡树中存放位置,这样查询排名第 k 大就可以在线段树上二分。时间复杂度优化成了 \(O(n\log^2 n)\),空间复杂度 \(O(n\log n)\)。应该是最优的解法。

有了树套树后,我们就能在线地做带修改的二维数点,不过如果能离线做那么还是写分治吧。

P9036 「KDOI-04」挑战 NPC Ⅲ

好题选讲里的一道题,我也觉得非常好(又水一道紫)

题目大意是求 \(n\) 个点的无向图中,大小为 \(n-k\) 的点独立集数量,\(k\le 18\)

首先转化成求大小为 \(k\) 的点覆盖边的数量。

考虑到 \(deg>k\) 的点都必须选,不然这些邻边就需要大于 \(k\) 个点来覆盖它们。

对于剩下的未覆盖的边,每次选一个点最多覆盖 \(k\) 条边,所以当剩余边数大于 \(k^2\) 时一定无解。

因为边不多,且选的点很少,考虑爆搜,我们枚举每一条未被覆盖的边,然后选择其中的一些端点,使它可以被覆盖,过程中要使得确定为选的点数量小于等于 \(k\)

\(c\) 为最后确定选的点数,\(s\) 为确定的点数(包括确定为选的和确定为不选的),则最后我们加上组合数 \(\binom {n-s} {k-c}\)

时间消耗大致是 \(O(2^kk^2)\),可以去看题解中的证明。

CF848C Goodbye Souvenir

我们记 \(pre_i\) 表示上一个与 \(i\) 相同的位置,\(nxt_i\) 表示下一个与 \(i\) 相同的位置。

那么一个数第一次出现当且仅当 \(l\le i\le r\land pre_i< l\)。最后一次出现当且仅当 \(l\le i\le r\land nxt_i>r\)

考虑到一次修改只会有 \(O(1)\)\(pre,nxt\) 被改变,我们用 set 可以轻易维护出每次修改后 \(pre,nxt\) 的变化。

我们再把上面的条件加上时间一维,加上贡献的正负,之后跑 cdq分治 即可。时间复杂度 \(O(n\log ^2n)\)

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

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

相关文章

OpenVX功能参数分析

3. 节点参数节点创建函数的参数定义为原子类型,如vx_int32、vx_enum,或对象,如vx_scalar、vx_image。框架应将节点创建功能的原子变量转换为vx_scalar引用,供节点使用。vx_scalar类型的节点参数,可以在图形执行期间更改;而如果改变原子类型的节点参数(vx_int32等),则至…

OpenVX参数节点执行独立性

8.节点执行独立性 在如图2-5所示例中,客户端根据输入图像、梯度幅度和梯度相位。OpenVX并不要求并行运行,但可以由OpenVX供应商实现。 图2-5 具有一些独立节点的简单图形。 构造这种图形的代码,如下所示。 vx_context context = vxCreateContext(); vx_image images[] = {…

4书推荐《AI芯片开发核心技术详解》、《智能汽车传感器:原理设计应用》、《TVM编译器原理与实践》、《LLVM编译器原理与实践》

4本书推荐《AI芯片开发核心技术详解》、《智能汽车传感器:原理设计应用》、《TVM编译器原理与实践》、《LLVM编译器原理与实践》由清华大学出版社资深编辑赵佳霓老师策划编辑的新书《AI芯片开发核心技术详解》已经出版,京东、淘宝天猫、当当等网上,相应陆陆续续可以购买。该…

BOF编写-修改时间戳

模板配置 跟着网上的教程使用evilashz师傅的模板,下载模板解压至vs的模板目录: %UserProfile%\Documents\Visual Studio 2022\Templates\ProjectTemplates​​ 创建新项目选择刚刚新增的类型:Beacon Object File​。 ​​ ‍ 环境适配 生成时报错,我使用的是2022版本的,模…

【分布式系统】 分布式调度 设计,要考虑 哪些问题?

一、分布式调度框架的核心功能二、什么是 任务调度 ?三、什么是分布式 任务调度 ?四、分布式调度框架的主要功能五、分布式调度框架的核心业务场景六、分布式任务调度的核心组件七、分布式任务调度的架构模式八、常见的分布式调度框架包括九、XXL-Job的工作流程十、 Quartz 的…

一文搞懂L1-L3业务流程体系分析,价值流、端到端流程、职能流程

今天我们聊聊业务流程体系分析这个话题。 业务流程的概念 业务流程是企业为实现目标而制定的一套系统化的工作方法。它由一系列有序的业务活动组成,按照既定规则将资源(输入)转化为有价值的结果(输出)。 在业务架构分析阶段,业务流程发挥着关键作用: • 明确业务运作的方…

[SSL/TLS/PKI] 基于`Let’s Encrypt`,获取免费SSL证书

缘起:云厂商卖的SSL证书太贵 概述:Let’s Encrypt 支持申请免费SSL证书的CA机构支持提供免费SSL证书的CA机构有:Let’s Encrypt ZeroSSL SSL For Free Cloudflare BuyPass AWS本文我们来试试 Let’s Encrypt 怎么用。https://letsencrypt.org/zh-cn/getting-started/Let’s …

.NET 响应式编程 System.Reactive 系列文章(二):深入理解 IObservableT 和 IObserverT

在 Rx 中,数据流的生产和消费是通过 观察者模式(Observer Pattern) 实现的。这种模式定义了两种角色: - IObservable.NET 响应式编程 System.Reactive 系列文章(二):深入理解 IObservable<T> 和 IObserver<T>引言:为什么我们调整了学习顺序? 在上一篇文章…

WebPack站点实战(一)

以下文章来源于一位不愿透露姓名的热心网友 ,作者不愿透露姓名的热心网友 文章配套B站视频,很多话语简略了,建议配着视频看。 地址:https://www.bilibili.com/video/BV13F411P7XB/ 开始之前了,简单过一下下面几个方法加深印象,便于更好理解加载器。也可以直接从webpack标…

CUDA概念

1.1.0f加个f,成单精度计算,不加会默认成double 2.快速指令:__add()加两个下划线 3.CUDA计算能力1.3以上才支持双精度,4.0往后支持双精度浮点计算 单精度浮点型(float )专指占用32位存储空间的单精度(single-precision )值。单精度在一些处理器上比双精度更快而且只占用…

12.09百度机器翻译SDK实验

一、实验要求百度机器翻译SDK实验(2024.11.15日完成) 任务一:下载配置百度翻译Java相关库及环境(占10%)。 任务二:了解百度翻译相关功能并进行总结,包括文本翻译-通用版和文本翻译-词典版(占20%)。 任务三:完成百度翻译相关功能代码并测试调用,要求可以实现…

弹性波动力学笔记(十)罗格里德斯公式推导

在应力计算中大量需要轴旋转公式计算,因此本笔记给出了罗格里德斯轴旋转公式Note: Derivation of the Rodriguez Formula In this Note, we will derive a formula for \(\mathbf{R}(\widehat{\mathbf{n}},\theta)\) . Consider the three dimensional rotation of a vecto…