Chapter 5 查找
Chapter 5 查找
1- 顺序查找法 O(n)
2- 折半查找O(logn) :二分查找
要求:关键字有序
过程:
判定树:叶子结点为方框,代表不成功的结点。
3- 分块查找:索引顺序查找
ASL = ASL1+ASL2
4- 二叉排序树(BST)
特点:左<根<右
5- 平衡二叉树(AVL)
6- B-树(B数)
特点:
1 分支数 = 关键字数 + 1,最大分支数就是B树的阶数
2 根结点至少有1个关键字,两个分支
其余结点至少有 个分支,
-1个关键字
3 结点内关键字互不相等按从小到大顺序排列
4 叶结点处于同一层,是查找失败到达的位置(计算结点数时要算上)
5 下层结点的关键字取值在上层所划分区间内
基本操作:
1 查找:多路查找
2 插入:可能引起拆分,多次拆分叫连锁反应
3 删除:直接删,不够找兄弟借,再不够合并
7- B+树
B-树和B+树的区别:(先B+,后B-)
1 B+树:n个关键字n个分支
B-树:n个关键字n+1个分支
2 关键字个数: ≤n≤m
-1≤n≤m-1
根结点个数: 2≤n≤m 1≤n≤m-1
3 B+树:非叶子结点只是个索引,不包含关键字对应记录的存储地址
B-树:每个关键字对应一个记录的存储地址
B+树:叶子结点包含信息和全部关键字,叶子结点引出的指针指向记录
B+树:有一个指针指向关键字最小的叶子结点,所有叶子结点链接成一个线性链表
8- 散列表(哈希表)
H(key) ---- 哈希地址
发生冲突----同义词
Hi(key)----解决冲突后的地址
查找成功的ASL1 = 每个关键字的比较次数
查找失败的ASL2 = 由该地址开始到空地址为止进行比较操作的次数
常见Hash函数构造方法:除留取余法
常见解决冲突方法:
1 开放定址法:包括线性探查法等…
2 链地址法:
性能分析:α(装填因子) = 关键字个数/表长
Hash表的ASL与α有关,与关键字无关。
注:
1 顺序表查找优点是顺序/链式均可,缺点是n较大时,ASL大,效率低
2 折半查找适合顺序,不适合链式,且要求有序
Chapter 5 查找的更多相关文章
- Chapter 8(查找)
1.二分查找和插值查找 //************************Search.h*********************************** #ifndef SEARCH_H # ...
- 【ASP.NET Identity系列教程(一)】ASP.NET Identity入门
注:本文是[ASP.NET Identity系列教程]的第一篇.本系列教程详细.完整.深入地介绍了微软的ASP.NET Identity技术,描述了如何运用ASP.NET Identity实现应用程序 ...
- ASP.NET Identity 一 (转载)
来源:http://www.cnblogs.com/r01cn/p/5194257.html 注:本文是[ASP.NET Identity系列教程]的第一篇.本系列教程详细.完整.深入地介绍了微软的A ...
- ASP.NET Identity系列教程-2【Identity入门】
https://www.cnblogs.com/r01cn/p/5177708.html13 Identity入门 Identity is a new API from Microsoft to ma ...
- Chapter 3: Connector(连接器)
一.概述 Tomcat或者称之为Catalina(开发名称),可以简化为两个主要的模块,如下图: 多个Connector关联一个Container.之所以需要多个Connector,是为了处理多种协议 ...
- Chapter Schema
Chapter Schema Schema是XF的核心,每一个读写方法都有一个相关联的Schema.方法首先解析Schema,然后再根据Schema的配置的执行. 那Schema是什么呢?Schema ...
- Chapter 1 Securing Your Server and Network(9):使用Kerberos用于身份验证
原文:Chapter 1 Securing Your Server and Network(9):使用Kerberos用于身份验证 原文出处:http://blog.csdn.net/dba_huan ...
- Linux - 在当前系统内查找信息的方法
查找文本 使用grep命令 grep命令 - 示例 grep命令 - 正则表达式 grep命令 - 统计匹配字符串的行数 grep命令 - 搜索多个单词 结合正则表达式使用grep命令 注意:在搜索指 ...
- 《Linux内核设计与实现》Chapter 18 读书笔记
<Linux内核设计与实现>Chapter 18 读书笔记 一.准备开始 一个bug 一个藏匿bug的内核版本 知道这个bug最早出现在哪个内核版本中. 相关内核代码的知识和运气 想要成功 ...
随机推荐
- JS对象 charAt() 方法可返回指定位置的字符。返回的字符是长度为 1 的字符串。
返回指定位置的字符 charAt() 方法可返回指定位置的字符.返回的字符是长度为 1 的字符串. 语法: stringObject.charAt(index) 参数说明: 注意:1.字符串中第一个字 ...
- Bootstrap 附加导航(Affix)插件
附加导航(Affix)插件允许指定 <div> 固定在页面的某个位置.一个常见的例子是社交图标.它们将在某个位置开始,但当页面点击某个标记,该 <div> 会锁定在某个位置,不 ...
- What is the difference between HTTP_CLIENT_IP and HTTP_X_FORWARDED_FOR
What is the difference between HTTP_CLIENT_IP and HTTP_X_FORWARDED_FOR? it is impossible to say. Dif ...
- Python自学:第五章 列表解析
# -*- coding: GBK -*- squares = [value**2 for value in range(1,11)] print(squares) 输出为: [1, 4, 9, 16 ...
- LUOGU P3413 SAC#1 - 萌数(数位dp)
传送门 解题思路 首先这道题如果有两个以上长度的回文串,那么就一定有三个或两个的回文串,所以只需要记录一下上一位和上上位填的数字就行了.数位\(dp\),用记忆化搜索来实现.设\(f[i][j][k] ...
- ul列表元素在float:right后li元素倒转
发现对li元素进行float:right后,虽然成功右浮动,但是的元素是倒转的 解决方案: 对ul进行右浮动,然后对li左浮动 结果
- 阿里云CentOs7上安装Mysql
前提:虽然yum源上有mysql,但是好像没有mysql-server,所以我们还是选择自己从官网上下载安装 一.新建文件夹,然后下载解压 cd /usr/ #新建mysql文件夹 mkdir mys ...
- 一个因为系统字号设置导致的rem计算渲染异常问题
测试同学突然拿着一部手机过来说,H5渲染各个元素都变大了,有些元素撑出了屏幕外面. 本来以为是某个Webview的渲染兼容问题,结果发现所有的浏览器都这样. 莫名其妙,隐约感觉是 rem计算出了问题, ...
- vue+element的el-menu组件实现路由跳转及当前项的设置
<el-menu router :default-active="$route.path" class="el-menu-vertical-demo" @ ...
- <每日一题>题目5:生成器表达式面试题
题目: def demo(): for i in range(4): yield i g = demo() g1 = (i for i in g ) g2 = (i for i in g1) prin ...