skip_list(推荐篇文章)

很惭愧, 这个东西是最近 在某人笔试心得 里 才听过.. 

 

简单介绍下, 具体算法见下面 链接.   英文的, 但是写的很 清楚 并且有 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实现巧妙之处.   链接中文章 有很详细的描述.

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值