数据结构速成--查找

由于是速成专题,因此内容不会十分全面,只会涵盖考试重点,各学校课程要求不同 ,大家可以按照考纲复习,不全面的内容,可以看一下小编主页数据结构初阶的内容,找到对应专题详细学习一下。

目录

一、顺序查找

二、折半查找

三、平衡二叉树(AVL树)

四、散列查找


一、顺序查找

顺序查找,主要用于线性表中进行查找。

二、折半查找

折半查找(二分查找),仅适用于有序的顺序表

这里涉及到了二叉排序树,注意左子树都小于根,右子树都大于根。树是递归定义的,所以记住左孩子<父结点,右孩子>父结点。

三、平衡二叉树(AVL树)

平衡二叉树就是左右子树高度之差的绝对值不超过1,就是说高度差=左子树高度-右子树高度=0、1、-1

当树不平衡时,我们就需要调整,我们要分清是什么结点导致了树的不平衡,比如左子树多了个左孩子,右子树多了个左孩子等等。

网上有很多调整平衡二叉树的教程,无非就是左旋和右旋。实际上我们只需要找到第一个不平衡结点,向下找两个连续的结点进行调整即可。

插入了90导致了66不平衡,就向下找两个连续的结点,一定要在66到90的路上找,所以找到了68、70,所以我们只需要对66、68、70三个结点进行调整,让这三个结点变成平衡二叉树,再把剩下的结点按性质插回去。

四、散列查找

相关推荐
冰清-小魔鱼9 小时前
各类数据存储结构总结
开发语言·数据结构·数据库
小六子成长记10 小时前
【C++】:搜索二叉树的模拟实现
数据结构·c++·算法
菜鸟233号11 小时前
力扣377 组合总和 Ⅳ java实现
java·数据结构·算法·leetcode
我是大咖11 小时前
二级指针与指针数组搭配
c语言·数据结构·算法
D_FW12 小时前
数据结构第五章:树与二叉树
数据结构·算法
余瑜鱼鱼鱼12 小时前
Java数据结构:从入门到精通(九)
数据结构
float_六七12 小时前
设备分配核心数据结构全解析
linux·服务器·数据结构
wifi chicken14 小时前
Linux 内核开发之单链表的增删查改详解
linux·数据结构·链表
im_AMBER15 小时前
数据结构 18 【复习】广义表 | 各种内部排序 | 二叉排序树的平均查找长度 ASL
数据结构·笔记·学习·排序算法
leaves falling18 小时前
冒泡排序(基础版+通用版)
数据结构·算法·排序算法