邓俊辉数据结构学习-8-2-B树】的更多相关文章

二叉搜索树(Binary-Search-Tree)--BST 要求:AVL树是BBST的一个种类,继承自BST,对于AVL树,不做太多掌握要求 四种旋转,旋转是BBST自平衡的基本,变换,主要掌握旋转的思想. 3+4重构,重点明白为什么可以3+4重构,而不是使用旋转 对于AVL插入和删除做了解,知道其为什么比不过红黑树就可以了. 循关键码访问(call-by-key) 关键码:就是所谓的key 条件: 关键码之间支持大小比较 支持相等比对 在BST中,所有数据都统一实现和表示为entry(ent…
B树 概述 动机: B树实现高速I/O 640K如何"满足"任何实际需求了-- 源自比尔·盖茨的一个笑话 前提知识 高速缓存 为什么高速缓存有效? 不同容量的存储器,访问速度差异悬殊,磁盘和内存访问速度的量级相差\(>10^5\) 如果将访问内存比喻为1秒,那么访问外存则相当于1天 因此我们需要尽量减少IO次数 分级I/O 俩个相邻存储级别之间的数据传输,统称为IO操作 CPU -> RAM -> DISK -> ARRAY 访问速度依次递减,存储容量依次递增…
邓公的数据结构一直好评如潮,可惜我如今才开始学习它.QAQ 昨天,<数据结构 (2020 春)>的讲义已经推到清华大学云盘上了.苦于 10 拼页的打印版不易在 PC 上阅读(手机上更是如此),而电子版又过于分散,因此制作了一份带索引的合并版本,现分享给大家:…
   文章图片代码来自邓俊辉老师的课件 概述 上图就是 B-Tree 的结构,可以看到这棵树和二叉树有点不同---"又矮又肥".同时子节点可以有若干个小的子节点构成.那么这样一棵树又有什么作用呢? 动机 我们知道电脑的访问内存比访问外的存I/O操作快了,但是内存的容量大小又只有那么一点点(相对于外存),所以计算机访问的过程常常使用高速缓存.使用高速缓存也是在以下两个事实想出的策略. 而B-Tree这种结构就是根据这种情况被发掘出来的.下图 m 指的是每次的数据块数量 B-Tree 介绍…
文章图片和代码来自邓俊辉老师课件 概述 伸展树(Splay Tree),也叫分裂树,是一种二叉排序树,它能在O(log n)内完成插入.查找和删除操作.它由丹尼尔·斯立特Daniel Sleator 和 罗伯特·恩卓·塔扬Robert Endre Tarjan 在1985年发明的.(出处百度百科) 它的操作就是将访问到的元素放在根节点处.主要的操作就是 zip 和 zag 下面是空间/时间复杂度(出处) 算法分析 双层伸展 双层伸展的作用是提升了树平均的访问性能.构思的精髓 : 向上追溯两层,而…
前言: 节主要是给出BST,AVL和红黑树的C++代码,方便自己以后的查阅,其代码依旧是data structures and algorithm analysis in c++ (second edition)一书的作者所给,关于这3中二叉树在前面的博文算法设计和数据结构学习_4(<数据结构和问题求解>part4笔记)中已经有所介绍.这里不会去详细介绍它们的实现和规则,一是因为这方面的介绍性资料超非常多,另外这3种树的难点都在插入和删除部分,其规则本身并不多,但是要用文字和图形解释其实还蛮耗…
数据结构学习之字符串匹配算法(BF||KMP) 0x1 实验目的 ​ 通过实验深入了解字符串常用的匹配算法(BF暴力匹配.KMP.优化KMP算法)思想. 0x2 实验要求 ​ 编写出BF暴力匹配.KMP.优化KMP的代码模型 0x2 代码 0x2.1.1 BF暴力匹配 #include <iostream> #include <string> using namespace std; int BF1(string s1,string s2) { int len=s2.length(…
数据结构学习之栈求解n皇后问题 0x1 目的 ​ 深入掌握栈应用的算法和设计 0x2 内容 ​ 编写一个程序exp3-8.cpp求解n皇后问题. 0x3 问题描述 即在n×n的方格棋盘上,放置n个皇后,要求每个皇后不同行.不同列.不同左右对角线. 要求:(1)皇后的个数n由用户输入,其值不能超过20,输出所有的解.(2)采用类似于栈求解迷宫问题的方法. 0x4 代码 #include <iostream> #include <cstdio> #include <cstdlib…
<Redis深度历险:核心原理和应用实践>1.基础: 万丈高楼平地起——Redis基础数据结构 学习记录http://naotu.baidu.com/file/b874e2624d3f377be4fb7980bc9358e2?token=1b07c0fdc1a3575f…
很多东西就是要细细的品读然后做点读书笔记,心理才会踏实- Javascript对象本质上就是键值对的集合(Hash结构),但是键只能是字符串,这有一定的限制. 1234 var d = {}var ele = document.bodyd[ele] = 'This is body'console.log(d['[object HTMLBodyElement]']) 上段代码的原意是将DOM节点作为对象d的键,由于对象只接受字符串,所以ele被自动转为[object HTMLBodyElement…