「补档计划」动态规划

dp 太弱,先补动规专题…

「补档计划」后缀平衡树

后缀平衡树是一种基于重量平衡树的非常有价值的数据结构,它可以在线维护 $sa$。

「黑科技」静态化 STL 容器内存

在 OI 中,我们手写的数据结构几乎都是静态内存的,而 STL 中的容器由于内存动态化的原因在做题中容易 TLE,这里介绍几种常见容器静态化内存的方法。

「补档计划」后缀数组

后缀数组的一些应用和题目,这里所有的时间复杂度均针对 SA-IS 算法。

「补档计划」随机化算法

模拟退火是一种通用概率算法,用来在固定时间内寻求在一个大的搜寻空间内找到的最优解。

「补档计划」计算几何

一些常见的计算几何。

「补档计划」k-d 树

k-d 树(k-dimensional tree)是在 $k$ 维欧几里德空间组织点的数据结构。k-d 树可以使用在多种应用场合,如多维键值搜索(例:范围搜寻及最邻近搜索)。k-d 树 是空间二分树(Binary space partitioning)的一种特殊情况。而在算法竞赛中,k-d树往往用于在二维平面内的信息检索,这里主要指二维 k-d 树。

「AtCoder BC061」题解

我并没有去打 CF,然后就跑去打第一场 AtCoder 刷水…

链接

AtCode BC061

「补档计划」最小费用流 Primal Dual 算法

求解最小费用流的算法有很多,如增广路算法(SPFA),消圈算法,zkw 算法,Primal Dual 算法及网络单纯形,其中消圈算法和网络单纯形较为通用但速度不够快或编程复杂度过高,SPFA 和 zkw 在不同的图上各有所长,这里介绍不容易被卡掉的 Primal Dual 算法。

注意: Primal Dual 算法也不能适用于存在负圈的图。

「补档计划」01-分数规划

写二分被卡 T 了,赶紧来补一补 01-分数规划的 Dinkelbach 算法…

「补档计划」最大流和最小割

一些最大流和最小割题目…
填坑中…

「补档计划」ISAP 和 HLPP 算法

求解网络流最大流问题有很多算法,ISAP 是图论求最大流的算法之一,它很好的平衡了运行时间和程序复杂度之间的关系,因此性价比很高。
而 HLPP 算法理论复杂度十分优秀,在实际运用中由于上界更紧而并不一定会快于 ISAP,但是 HLPP 在分层图中表现十分出色,甚至比在分层图上复杂度为 $O(n^2)$ 的 MPM 算法还快。
这里简单的给出这两个算法的思想以及代码实现。

「CQOI2017」系列题解

小Q的棋盘

小Q 正在设计一种棋类游戏。在小Q设计的游戏中,棋子可以放在棋盘上的格点中。某些格点之间有连线,棋子只能在有连线的格点之间移动。整个棋盘上共有 $V$ 个格点,编号为 $0,1,2, \cdots, V-1$,它们是连通的,也就是说棋子从任意格点出发,总能到达所有的格点。小Q 在设计棋盘时,还保证棋子从一个格点移动到另外任一格点的路径是唯一的。

小Q 现在想知道,当棋子从格点 $0$ 出发,移动 $N$ 步最多能经过多少格点。格点可以重复经过多次,但不重复计数。

「补档计划」Tarjan

复习 Tarjan 算法以及一些常见的应用。

「BZOJ-4860」「BJOI-2017」树的难题

给你一棵 $n$ 个点的无根树。

树上的每条边具有颜色。一共有 $m$ 种颜色,编号为 $1$ 到 $m$。第 $i$ 种颜色的权值为 $c_i$。

对于一条树上的简单路径,路径上经过的所有边按顺序组成一个颜色序列,序列可以划

分成若干个相同颜色段。定义路径权值为颜色序列上每个同颜色段的颜色权值之和。

请你计算,经过边数在 $l$ 到 $r$ 之间的所有简单路径中,路径权值的最大值。

「补档计划」矩阵乘法及其优化

矩阵相乘最重要的方法是一般矩阵乘积。它只有在第一个矩阵的列数(column)和第二个矩阵的行数(row)相同时才有意义,这里给出常见的几种实现方式,以及它们性能的比较,然后再给出几种优化,这里的优化是针对 $O(n^3)$ 朴素矩阵乘法的优化,因为朴素算法更容易利用硬件进行优化。

Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×