很惭愧, 这个东西是最近 在某人笔试心得 里 才听过..
简单介绍下, 具体算法见下面 链接. 英文的, 但是写的很 清楚 并且有 C#的代码实现. 非常好.
http://www.codersource.net/csharp_skip_list.aspx
一般学数据结构, 最早接触的就是 二分查找 吧.. O(lgN)的效率是相当nb的.
二分查找 使用条件: 1, 顺序表(就是数组, 可随机定位). 2, 排序好..
条件1 是线性链表 无法 达到的. 所以对 即使排序好的 单链表, 还是要O(N) 的 查找. (当然可以用 树, 事实上, skip_list 就是 用来 代替树的. 因为后者 在 极端 情况下, 就变成 线性表)
为了解决 二分查找 随机 访问的 瓶颈, skip_list给 每个节点 多个 指针.
比如: 第一个元素 增加一个指针 使其指向 最中间元素. 这样, 在查找时, 可像 二分查找一样, 确定 是从 链表 前半部分, 还是 后半部分 进行.. 以此类推... 这可能就是 skip_list 产生的动机吧..
但是, 问题是 开始时 ,根本无法 确定 需要多少个指针, 这是skip_list实现巧妙之处. 链接中文章 有很详细的描述.