查找算法

 

最近在找工作,在这里记下一些查找相关的问题。

一、静态查找表:

 

1.顺序查找,从表中最后一个记录开始,逐个进行记录的关键字和给定值的比较,若某个关键字和给定值比较相等,则查找成功;若直到第一记录其关键字和给定值比较都不相等,则表明表中没有所查记录,查找失败。

 

对于有n个记录的表,在等概率情况下顺序查找的平均查找长度为 (n+1)/2

 

2.折半查找。要求查找表为有序表。low和high表示查找范围的下界和上界,mid= (low+high)/2 向下取整

                 设查找关键字为key,

                 1)当key<mid,则high=mid-1,重新计算mid

                 2)当key>mid,  则low=mid+1,重新计算mid

                 3)当key==mid,查找成功

                 4)当low>high,查找失败

 查找不成功时,查找次数为 log2 n,下取整+1;平均查找长度为log2 (n+1) -1

 

二、动态查找表:

 

1.二叉排序树 (华为的一面中被问到)

简单来说就是,左子树 <根 < 右子树。 中序遍历二叉排序树可得一个关键字得有序序列。也就是说无序序列可以通过构建一颗二叉排序树而变成一个有序序列

 

三、哈希表

 

1.哈希函数构造方法: 1)直接定址 2)数字分析法 3)平方取中法 4) 折叠法 5)除留余数法 6)随机数法

2.冲突处理方法:       1) 开发定址法 2) 再哈希 3)链地址 4)建立公共溢出区

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值