数据结构-查找-线性表查找-科班学习笔记

本文介绍了数据结构中的线性表查找,包括顺序查找和折半查找(二分查找)。详细阐述了这两种查找方法的基本概念、性能指标ASL、时间复杂度以及优缺点。顺序查找的平均查找长度在成功和失败时的计算,而折半查找则要求线性表有序,其ASL和效率更高。
摘要由CSDN通过智能技术生成

数据结构-查找-线性表查找(顺序、二分、ASL)-科班学习笔记

查找的博客会出三篇,此为第一篇,先得了解一些基本概念,如有基础的朋友可跳过,直接看算法

查找基本概念

专业名词


查找

又称检索,是v指在某种数据结构中找出满足给定条件的元素

查找表:

一组记录组成的表或文件,每个记录由若干个数据项组成

关键字key:

记录中能唯一标识该记录的数据

内查找外查找:

查找过程在内存进行称内查找,查找过程需访问外存,称外查找

动态查找(dynamic search):

查找的同时进行增删改操作,查找表称动态查找表

静态查找(static search)

单纯查找,查找表称静态查找表

查找方法概述

根据存储结构的不同,查找方法可分为三大类

  • 顺序表和链表的查找

将给定的K值与查找表中记录的关键字逐个进行比较, 找到要查找的记录

  • 散列表的查找

    根据给定的K值直接访问查找表, 从而找到要查找的记录

  • 索引查找表的查找

    根据索引确定待查找记录所在的,然后再从块中找到要查找的记录

常见查找方法有

  • 顺序查找
  • 二分查找
  • 二叉排序树查找
  • 索引查找
  • 散列查找
  • B树查找

查找方法的性能指标ASL

通常把查找过程中执行的关键字平均比较个数(也称为平均查找长度)作为衡量一个查找算法效率优劣的标准

其中:

  • n是查找表中记录的个数
  • pi是查找到第i个记录的概率,一般认为每个记录概率相等,即p=1/n
  • ci是到到第i个记录所需的比较次数

简而言之,ASL = 每个结点的关键字比较次数累加/节点数

接下来进入正题

线性表查找

顺序表类型定义

#define MAXL <表中最多记录个数>

typedef struct

{
   	KeyType key;	//KeyType为关键字的数据类型
	InfoType	data;	//数据项
}	RecType;		//查找顺序表元素类型

顺序查找

思路:从

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值