
算法
JonahMoon
这个作者很懒,什么都没留下…
展开
-
红黑树的基本操作之添加
红黑树的基本操作之添加 R-B Tree,全称是Red-Black Tree,又称为“红黑树”,它一种特殊的二叉查找树。红黑树的每个节点上都有存储位表示节点的颜色,可以是红(Red)或黑(Black)。 红黑树的特性:(1)每个节点或者是黑色,或者是红色。(2)根节点是黑色。(3)每个叶子节点(NIL)是黑色。[注意:这里叶子节点,是指为空(NIL或NULL)的叶子节点!](4)如果一个节点...原创 2019-03-20 08:32:19 · 315 阅读 · 0 评论 -
Bellman-Ford算法
前言 Bellman-Ford算法,限于资料匮乏和时间复杂度比Dijkstra算法高,包括白书在内的很多资料,都没说得太明白。对于优化后的SPFA算法也没有提及。 而且最短路问题通常是作为图论的入门问题,学习者通常没有图论基础,不知道图论的一些基本常识,看已有的资料很容易产生疑惑。其实,从Bellman-ford算法优化到SPFA算法实际上是顺理成章的。 本文旨在阐明这两个算法思想和步骤,如果...转载 2019-03-20 18:42:24 · 2793 阅读 · 3 评论 -
滚动数组
滚动数组的作用在于优化空间,主要应用在递推或动态规划中(如01背包问题)。因为DP题目是一个自底向上的扩展过程,我们常常需要用到的是连续的解,前面的解往往可以舍去。所以用滚动数组优化是很有效的。利用滚动数组的话在N很大的情况下可以达到压缩存储的作用。 一个简单的例子: 斐波那契数列: 一般代码: #include<iostream> #include<cstdio>...转载 2019-03-12 17:39:09 · 243 阅读 · 0 评论 -
关于KMP算法的next数组
KMP的next数组求法是很不容易搞清楚的一部分,也是最重要的一部分。我这篇文章就以我自己的感悟来慢慢推导一下吧!保证你看完过后是知其然,也知其所以然。 如果你还不知道KMP是什么,请先阅读上面的链接,先搞懂KMP是要干什么。 下面我们就来说说KMP的next数组求法。 KMP的next数组简单来说,假设有两个字符串,一个是待匹配的字符串strText,一个是要查找的关键字strKey。现在我们...转载 2019-03-17 22:35:24 · 220 阅读 · 0 评论