平衡二叉树
一棵AVL树满足以下的条件:
1.它的左子树和右子树都是AVL树
2.左子树和右子树的高度差不能超过1
哈夫曼树
KMP算法描述
B+树和B树的区别
如图所示,区别有以下两点:
- B+树中只有叶子节点会带有指向记录的指针(ROWID),而B树则所有节点都带有,在内部节点出现的索引项不会再出现在叶子节点中。
- B+树中所有叶子节点都是通过指针连接在一起,而B树不会。
B+树的优点:
- 非叶子节点不会带上ROWID,这样,一个块中可以容纳更多的索引项,一是可以降低树的高度。二是一个内部节点可以定位更多的叶子节点。
- 叶子节点之间通过指针来连接,范围扫描将十分简单,而对于B树来说,则需要在叶子节点和内部节点不停的往返移动。
B树的优点:
对于在内部节点的数据,可直接得到,不必根据叶子节点来定位。
插入节点怎么分裂
二分查找,递归和非递归
红黑树的实现, TreeSet 的实现
红黑树简单说了一下它的特性、性能和优缺点
1、每个节点不是红色就是黑色。
2、根节点为黑色。
3、如果节点为红色,其子节点必须为黑色。
4、任意一个节点到到NULL(树尾端)的任何路径,所含之黑色节点数必须相同。
红黑树并不追求“完全平衡”——它只要求部分地达到平衡要求,降低了对旋转的要求,从而提高了性能。
红黑树能够以O(log2 n) 的时间复杂度进行搜索、插入、删除操作。此外,由于它的设计,任何不平衡都会在三次旋转之内解决。
红黑树和平衡二叉树区别
排序的种类、稳定性、时间复杂度,适用场景
Java 中堆的实现类,堆排序的思路
从 1 亿游戏积分数据中,如何选择前 200 名最高积分
手写冒泡排序
手写堆排序
如何测一个云朵的质量
手写上 n 个台阶总共方法数,(每次上 1 、 2 或 3 阶),递归及非递归实现
手写代码:在一组有序数组中,找出两个数,使得其和为给定和
只用一个变量,如何表示象棋中两方 “ 将 ”“ 帅 ” 的可走位置
找出增序排列中一个数字第一次和最后一次出现的数组下标,数据去重,海量数据去重,找出海量数据中前10个最大的数(数据有重复)
数组先升序在降序,找出最大数
个正整数数组,给其中一个数字加1,使得所有数乘积最大,找出加1的那个数字
10G文件的淘宝商品编号,只有512M内存,怎么判断究竟是不是合法编号(即编号是否存在)
假如淘宝存着一个包含10w个敏感词的词库,紧接着需要从多个商品标题中随机抽查3个有没有包含敏感词的商品
20亿QQ号的插入与查找最小存储开销实现方案
图的 prime 算法 kruskal 算法 dijkstra算法 解决什么问题? 分别写一下 伪代码
海量URL数据,低内存情况下找重复次数最高的那一个
写大数加法代码
设计一个洗牌发牌算法
动态规划的思想
怎么统计大日志文件访问量前十的ip
知道LRU吗,20分钟基于Hashmap实现一个LRU算法
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。