对各种数据结构的感受

树状数组:

可以用来维护前缀的,满足交换律的东西?
方便好写,常数极小,但使用范围不广。
其实二分套树状数组可以通过倍增来做到 \(O(\log n)\) 的。

并查集:

可以用来维护一些联通块,无论是数值的还是位置上的。
特征也比较明显,因为应该没人写 ds 时维护 bfs 的状态吧!
要求是必须只关心整个块的信息,不能关心某几个跟他链接的点的信息。
常数也很小,不亚于树状数组。

线段树:

算是一种非常常用的数据结构了。
可以在 \(O(merge) \log n\) 的时间复杂度内完成任何满足交换律的东西。
一些技巧:

大多数二分套线段树可以被线段树二分/单侧递归线段树等来做到 \(O(\log)\)
线段树合并 \(n\) 个大小为 \(n\) 的集合的时间复杂度为 \(O(n \log n)\),可以通过势能分析。
动态开点线段树:是一种时间,空间都比较劣的线段树,但可以支持范围很大,重要的点较少的线段树。

主席树:

就是可持久化线段树,可以快速地在空间,时间都为 \(O(n \log n)\) 地限制内求出类似查询区间不同数地数量这种较复杂的东西的线段树,比线段树的优势在于可以支持区间求数值的操作。
一般是维护地权值线段树,然后建 \(n\) 棵线段树。

但主席树不支持修改,如果是动态区间第 k 大的话就得树套树,外层再套一个树状数组。
主席树有懒标记的话得开 3 倍空间。

猫树:

离线的线段树。
猫树的优势在于,只要线段树能做的无强制在线的,猫树几乎都能做。
大体思路就是离线,然后分治,对于每个 \(x \in l \sim mid\)\(y \in mid + 1 \sim r\) 的查询,预处理出左边的每一个后缀,右边的每一个前缀,再暴力合并即可。
往往能达到很好的效果。

平衡树:

treap 感觉没什么用,因为不支持区间操作。
FHQ 的本质就是通过很多次分裂于合并让树高不会太高。
Splay 的本质是时间复杂度均摊,每次将询问的点旋到根,且复杂度严格 \(log\),也就是因为复杂度均摊,所以 LCT 用 Splay 的话是单 log。
支持 reverse 操作。

分块:

比较全能的数据结构。
他对于线段树的优势在于:能做更多的操作。
有的时候线段树不方便下传标记,或者将多个标记合并时,就可以考虑分块。
前面分块唯一不能取代的就是不支持 reverse 操作。
且分块的常数和时间复杂度都不小。
谨慎使用。

莫队:

也是一种离线算法。
本质就是当你直接做不好做,且知道 \(l,r\) 之后就能知道 \(l,r+1\) 类似这种东西时可以考虑莫队。

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

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

相关文章

webdriver打开Chrome闪退问题的解决方法

现状:webdriver控制打开Chrome后闪退解决方案:强制等待,使用time.sleep()

noip 2025.2.22

T3 题目大意: 给你一棵树和一个排列 \(p\),定义 \(l \sim r\) 的 \(val\) 值为 \(dep_{LCA(p_{l \sim r})}\),求 \[\sum_{i = 1}^n \sum_{j=i}^n val_{l, r} \]\(n \le 6 \times 10^5\) 赛时思路: 先将 p 给直接映射上去。 考虑 \(\text{dsu on tree}\),用 set 维护每个子…

Java基础day3

Scanner对象 方法的重载 方法的调用 命令行传参 可变参数 数组 类与对象 封装,继承-extendsJava基础day3 Scanner对象Scanner scanner=new Scanner(System.in);if(scanner.hasNext()){//用next接收String str=scanner.nextLine();System.out.println("输出内容…

2025-02-22-steampy-on-steam

Why 官方 插件僅做了 Chrome 版本,並且尚未上架,想給 FF 也做一個。因爲功能比較簡單,所以試圖用 Tampermonkey 做了一個版本出來,想着自己湊合中,因爲本人不需要代購價格,所以僅僅顯示 CDKey 的價格。總體樣式和官方的差距比較多,這個只是一個 Demo 腳本,後續有空了會…

[题解]AtCoder Beginner Contest 394(ABC394)

A - 22222 遍历字符串\(s\),按题意输出所有2即可。点击查看代码 #include<bits/stdc++.h> #define int long long using namespace std; string s; signed main(){cin>>s;for(auto a:s) if(a==2) cout<<a;return 0; }B - cat 按题意模拟即可。点击查看代码 …

GitOps项目上篇之Argo CD环境准备

作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任。 目录一.GitOps概述1.什么是GitOps2.基于Argo实现GitOps方案架构二.GitOps项目环境准备实战案例1.主机角色规划2.部署gitlab相关环境3.部署k8s相关环境4.部署ArgoCD默认启用tls环境基于NodePort暴露4.1 Argo概…

[tldr] 配置windows terminal使用git bash

windows terminal默认使用power shell作为shell,但是power shell不好用,还是习惯linux的命令行行为. 参考Windows Terminal 配置 Git Bash 添加新的配置文件在windows terminal中点击设置选项点击添加配置文件按钮编辑配置内容 一个配置文件主要来自之前的配置文件的内容主要分…

【原创工具】文件清单生成器 By怜渠客

【原创工具】文件清单生成器 By怜渠客 刚在论坛看到了一个文件列表生成器 https://www.52pojie.cn/thread-2008605-1-1.html ,和我去年写的一个软件很像,当时我也是有需求,要把一个文件夹里及其子文件夹里所有的文件列出来,就临时弄了个小软件,现在我重新修复完善了一下,…

windows使用命令行管理进程

前言 在windows中,我们通常使用GUI图形画面的任务管理器来管理进程。 任务管理器提供了一个较为友好的图形界面,然而他也存在一定问题。 首先,任务管理器就要吃掉一部分性能。 而且,当你在任务管理器页面,点击按名称排序时,那可能会出现灾难性的卡顿,这对一台旧电脑来说…

postman的几种参数化

1.环境变量方式设置:创建环境:点击 Postman 右上角的 Environments > Create New。输入环境名称(如 Dev、test),并添加键值对(如 base_url: https://api.vvhan.com)。使用变量:在请求 URL 或请求体中用双花括号引用变量:{{base_url}}/users。切换环境时,变量会自动…

第十五届蓝桥杯省赛

第十五届蓝桥杯省赛 1.握手问题#include <iostream> using namespace std; int main() { //划分为43,7两组 //(43*42)/2+7*43=28*43 cout<<28*43;return 0; }2.小球反弹(难)分析: 当做两个方向往返代码:/* 考点:速度分解 分解为x轴往返,y轴往返(回到左上角起…

OpenWRT安装Caddy实现WebDAV协议的NAS盘

Caddy带有WebDAV插件,可以安装在OpenWRT上,用于提供WebDAV协议的NAS服务。 Windows资源管理器,WinSCP,MAC的Finder,Android上的CX文件管理器都可以作为WebDAV的客户端。 WebDAV使用过程中可以直接打开文件,修改后保存,非常方便,感觉Samb没区别。但其使用https协议,安全…