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 查找的更多相关文章

  1. Chapter 8(查找)

    1.二分查找和插值查找 //************************Search.h*********************************** #ifndef SEARCH_H # ...

  2. 【ASP.NET Identity系列教程(一)】ASP.NET Identity入门

    注:本文是[ASP.NET Identity系列教程]的第一篇.本系列教程详细.完整.深入地介绍了微软的ASP.NET Identity技术,描述了如何运用ASP.NET Identity实现应用程序 ...

  3. ASP.NET Identity 一 (转载)

    来源:http://www.cnblogs.com/r01cn/p/5194257.html 注:本文是[ASP.NET Identity系列教程]的第一篇.本系列教程详细.完整.深入地介绍了微软的A ...

  4. ASP.NET Identity系列教程-2【Identity入门】

    https://www.cnblogs.com/r01cn/p/5177708.html13 Identity入门 Identity is a new API from Microsoft to ma ...

  5. Chapter 3: Connector(连接器)

    一.概述 Tomcat或者称之为Catalina(开发名称),可以简化为两个主要的模块,如下图: 多个Connector关联一个Container.之所以需要多个Connector,是为了处理多种协议 ...

  6. Chapter Schema

    Chapter Schema Schema是XF的核心,每一个读写方法都有一个相关联的Schema.方法首先解析Schema,然后再根据Schema的配置的执行. 那Schema是什么呢?Schema ...

  7. Chapter 1 Securing Your Server and Network(9):使用Kerberos用于身份验证

    原文:Chapter 1 Securing Your Server and Network(9):使用Kerberos用于身份验证 原文出处:http://blog.csdn.net/dba_huan ...

  8. Linux - 在当前系统内查找信息的方法

    查找文本 使用grep命令 grep命令 - 示例 grep命令 - 正则表达式 grep命令 - 统计匹配字符串的行数 grep命令 - 搜索多个单词 结合正则表达式使用grep命令 注意:在搜索指 ...

  9. 《Linux内核设计与实现》Chapter 18 读书笔记

    <Linux内核设计与实现>Chapter 18 读书笔记 一.准备开始 一个bug 一个藏匿bug的内核版本 知道这个bug最早出现在哪个内核版本中. 相关内核代码的知识和运气 想要成功 ...

随机推荐

  1. Ansible的copy模块批量下发文件

    copy模块的参数,ansible 主机组 -m copy -a '' src: 指定源文件或目录 dest: 指定目标服务器的文件或目录 backup: 是否要备份 owner: 拷贝到目标服务器后 ...

  2. 详解redis服务

    http://mp.weixin.qq.com/s?__biz=MzIyMDA1MzgyNw==&mid=2651968327&idx=1&sn=6e6cb01d334d7ae ...

  3. 【转】40个Java多线程问题总结

    文章转自 五月的仓颉 http://www.cnblogs.com/xrq730/p/5060921.html 前言 Java多线程分类中写了21篇多线程的文章,21篇文章的内容很多,个人认为,学习, ...

  4. AM8后台历史数据手工清理方法

    AM8后台历史数据手工清理方法 数据清理目前通过bat脚本将windows任务计划来完成 Bat 路径位置: \ActiveSoft\Am8Svr\STKServer\Data    (请根据服务安装 ...

  5. arc098E Range Minimum Queries

    题意:给你一个n个数的数组,每次能够选取连续的长度为K的子序列,取出其中任意一个最小元素. 一共操作Q次.问取出的元素中Max-Min最小是多少? 标程: #include<bits/stdc+ ...

  6. linux shell下除了某个文件外的其他文件全部删除的命令

    Linux反选删除文件 最简单的方法是 # shopt -s extglob      (打开extglob模式) # rm -fr !(file1)  如果是多个要排除的,可以这样: # rm -r ...

  7. Java Collection - 遍历map的几种方式

    作者:zhaoguhong(赵孤鸿) 出处:http://www.cnblogs.com/zhaoguhong/ 本文版权归作者和博客园共有,转载请注明出处 ---------------- 总结 如 ...

  8. 共享商业&技术红利,阿里云SaaS加速器让天下没有难做的SaaS

    9月26日,阿里云在2019杭州云栖大会上发布了SaaS加速器3.0版“一云多端”多个应用平台,展示了阿里云给伙伴带来的多种商业和技术红利.阿里云SaaS加速器将帮助伙伴做好SaaS,卖好SaaS:帮 ...

  9. thinkphp 自动加载

    在3.2中,基本上无需手动加载类库文件,你可以很方便的完成自动加载. 命名空间自动加载 系统可以通过类的命名空间自动定位到类库文件,例如: 我们定义了一个类 Org\Util\Auth 类: name ...

  10. LUOGU P2290 [HNOI2004]树的计数(组合数,prufer序)

    传送门 解题思路 \(prufer\)序,就是所有的不同的无根树,都可以转化为唯一的序列.做法就是每次从度数为\(1\)的点中选出一个字典序最小的,把这个点删掉,并把这个点相连的节点加入序列,直到只剩 ...