谁说有序链表不能进行二分查找,只是需要进化而已?!

前言

本文收录于专辑:http://dwz.win/HjK,点击解锁更多数据结构与算法的知识。

你好,我是彤哥。

上一节,我们一起学习了关于哈希的一切,特别是哈希表的进化过程,相信通过上一节的学习,你一定可以从头到尾完整地给面试官讲讲哈希表是如何发展到如今这一步的。

但是,难道HashMap的终极形态只能通过“数组+链表+红黑树”的形式实现吗?有没有可替代方案?为什么Java没有使用你说的这种替代方案呢?

本节,我们就来学习另外一种数据结构——跳表,关于跳表的内容,我将分成两节完成,第一节介绍跳表的演进过程,第二节代码实现跳表,并改写HashMap。

好了,让我们先进入跳表第一小节的学习。

有序数组

大家都知道数组是可以支持随机访问的,也就是通过下标可以快速地定位到元素,时间复杂度是O(1)。

那么,这个随机访问的特性除了根据下标查找元素,还具有哪些用处呢?

试想,如果一个数组是有序的,我要查找某个指定的元素,如何才能做到最快速地查找出来呢?

0

简单地方法,从头开始遍历整个数组,遇到了要查找的元素就返回,比如,查找8这个元素,要走6次才能查找到,要查找10这个元素更夸张,需要8次。

所以,这种方式的查找元素的时间复杂度为O(n)。

1

快速地方法,因为数组本身是有序的,所以,我们可以使用二分查找,先从中间开始查找,如果指定元素比中间的元素小,再在左半边查找,如果指定元素比中间元素大,则在右半边查找,依次进行,直到找到指定元素。比如,查找8这个元素,先定位到中间(7/2=3)的位置,下一次查找让左指针加1,把4号位置作为左指针,中间的位置变为(4+(7-4)/2=5)的位置,查找到8这个元素,一共只需要2次。

使用二分查找ÿ

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值