对于一个有序数组,如果要查找其中的一个数,我们可以使用二分查找(Binary Search)算法,将它的时间复杂度降低为O(logn).那查找一个有序链表,有没有办法将其时间复杂度也降低为O(logn)呢? 跳表(skip list),全称为跳跃链表,实质上就是一种可以进行二分查找的有序链表,它允许快速查询.插入和删除有序链表. 跳表使用的前提是链表有序,就像二分查找也要求有序数组 怎么理解跳表 比如我们有一个原始有序链表,如下图所示. 要查找其中值为20的元素,之前都是采取按顺序进行遍历的方法