码迷,mamicode.com
首页 > 其他好文 > 详细

数据结构《20》----Immutable stack

时间:2017-06-24 10:06:02      阅读:119      评论:0      收藏:0      [点我收藏+]

标签:pos   多个   csdn   基本   bmp   out   south   max   理想   

有趣的函数式数据结构《一》----不可变栈

什么是不可变?往栈中插入一个元素,原来的栈保持不变,返回一个新的栈(已插入新的元素)。

push, pop,getMax 等操作都要求在 常数时间内完毕。


可能读者会产生疑惑,既然要返回一个新的栈,是不是就必须先拷贝一份原来的栈,然后在新的栈中插入元素。

可是这样复杂度就是线性的,怎样可以在常数时间内完毕呢??

这里。就是immutable DATA STRUCTRUE 的强大。。


本文给出一个C++ 的实现版本号,基本理想是利用内存共享,以及均摊时间的思想。

下图给出了实现的核心思想。

三个链表[1,2,3], [1,2,4], [1,2,5]共用节点1,2

这是由于一个节点能够有多个前驱节点指向它本身。。而栈的特性:只在链表的头部插入删除的性质保证了节点的共享。


技术分享



数据结构《20》----Immutable stack

标签:pos   多个   csdn   基本   bmp   out   south   max   理想   

原文地址:http://www.cnblogs.com/gavanwanggw/p/7072438.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!