首页 技术 正文
技术 2022年11月22日
0 收藏 654 点赞 3,045 浏览 665 个字

实践博客

二分法查找元素
  • 1.首先定义三个位置min,mid,max
  • 2.每次从所有元素所处位置的中间开始查找(所有元素必须以由小及大顺序排列完毕)
  • 3.当中间元素大于所查找元素时,从中间元素(mid)左半区进行查找,此时max元素由最大值变为mid左侧紧邻的那个元素,min元素不变。
  • 4.当中间元素小于所查找元素时,从中间元素(mid)右半区进行查找,此时max位置不变,min元素由最小元素变为mid元素的紧邻的右侧元素,max元素不变
  • 5.当所查元素与mid元素相等时,查找结束。
  • 6.当未查找到时,重复3、4步骤,直至查找到所需元素。
ASL分析
  • ASL,Average Search Length,是查找算法的查找成功时的平均查找长度的缩写,是为确定记录在查找表中的位置,需和给定值进行比较的关键字个数的期望值。
  • 二分法的ASL
1 2 3 4 5 6 7 8 9 10 11
05 13 19 21 37 56 64 75 80 88 92
3 4 2 3 4 1 3 4 2 3 4
  • 第一行为索引,第二行为元素,第三行为查找到该元素所需要的次数。
  • 所以该元素集合的ASL=(1+2 * 2 + 3 * 4 + 4 * 4)/11=3

时间算法复杂度分析

  • 二分法每次可以排除一半不符合要求的元素
  • 对于n个元素
  • 1.第一次剩下n/2
  • 2.第二次剩下n/4
  • 3.n次剩下n/(2^m)
  • 所以,时间复杂度为log₂(n)
  • 补充,对于第一个,第二个数即05,13元素,他们的搜寻次数为3和4.这取决于其具体的代码实现,不同的比较顺序可以带来不同的搜寻次数,例如,先从远离最后一次中间元素开始,那么05为3次,从靠近最后一次中间元素开始,05就会变为4次。
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,031
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,520
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,368
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,148
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,781
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,860