转载自大佬整理的题单,太强了🙌 : 灵茶山艾府
基础算法精讲·题目汇总
大家好,我是 灵茶山艾府。
我制作了一系列算法教学视频,整理成合集【基础算法精讲】。以下是合集中的视频链接、配套题目和代码,代码包含 Python/Java/C++/Go 等多种语言。
制作不易,欢迎点赞,也欢迎转发给你的朋友或刷题群!
其他尚未更新的 topic 请看 题解精选(已分类)
算法题单
- 滑动窗口与双指针(定长/不定长/单序列/双序列/三指针/分组循环)
- 二分算法(二分答案/最小化最大值/最大化最小值/第K小)
- 单调栈(基础/矩形面积/贡献法/最小字典序)
- 网格图(DFS/BFS/综合应用)
- 位运算(基础/性质/拆位/试填/恒等式/思维)
- 图论算法(DFS/BFS/拓扑排序/最短路/最小生成树/二分图/基环树/欧拉路径)
- 🔥动态规划(入门/背包/状态机/划分/区间/状压/数位/数据结构优化/树形/博弈/概率期望)
- 常用数据结构(前缀和/差分/栈/队列/堆/字典树/并查集/树状数组/线段树)
- 数学算法(数论/组合/概率期望/博弈/计算几何/随机算法)
- 贪心与思维(基本贪心策略/反悔/区间/字典序/数学/思维/脑筋急转弯/构造)
- 链表、二叉树与回溯(前后指针/快慢指针/DFS/BFS/直径/LCA/一般树)
- 字符串(KMP/Z函数/Manacher/字符串哈希/AC自动机/后缀数组/子序列自动机)
周赛总结
其他
相向双指针
小tips:可以通过获取的信息量来衡量一个算法的效率.
双指针的精髓:用O1的时间,获取到On的信息.
(因为每次移动都能够排除多个不可能的组合)
167. 两数之和 II - 输入有序数组比如这道题目
暴力做法枚举每个数,然后和target作比较,O1的时间就获取到了O1的信息.
而双指针的方法将剩下的数和最大的数对比,O1的时间获取到了On的信息.
线段树
以这道题目水果成篮III为例,入门线段树.
线段树发明的动机
虽然说数组无序,但是仍然可以通过二分的方式寻找需要的位置,如果左半边有就排除右半边,如果左半边没有就排除左半边.并且每次二分,都是原问题相同的更小子问题,也就是继续寻找左右半边最大的容器.
为什么要这么设计线段树
通过线段树,可以维护所有需要的情况的数据.
并且在查找后,需要重新修正节点.
所以需要的操作就是:找到最左边大于等于x的位置;将该位置改成-1.
线段树模板
1 | class SegmentTree { |