Python 用 list 来模拟循环双链表有什么好处么?

2016-08-18 12:40:41 +08:00
 geeti
比如在 lib/functools.py 的 lru_cache 中,

root = []
root[:] = [root,root,None,None]
root 作为循环双链表的一个点。这样做的好处是啥?
如果定义链表的 class ,感觉应该更省内存吧?
2935 次点击
所在节点    Python
8 条回复
zonghua
2016-08-18 12:45:33 +08:00
实际上是作为循环队列, LRU 就是最少使用缓存算法,队列里把最少用到的排挤掉。用数组每次插入只要从新标志队头和队尾。
geeti
2016-08-18 12:52:56 +08:00
@zonghua 我知道这是 lru 的原理。

我想问的是,这里就用一个 list ,而不是定一个 class node(),然后写成链表。后者貌似更省内存
geeti
2016-08-18 12:57:20 +08:00
刷题感想。 leetcode 的 LRU 那道题,大家都是定义 linked list,但我发现 functools 里边直接使用 list ,特别简洁。但好像一个 list 比同样一个 node object 要耗内存
wodesuck
2016-08-18 14:20:43 +08:00
python 的 object 并不省内存,里面还有__dict__。。
SlipStupig
2016-08-18 16:13:09 +08:00
@wodesuck 定义一下 __slots__就好了
langyu
2016-08-18 21:15:20 +08:00
意义不大, 就像用汽车来模拟自行车一样。
wizardforcel
2016-08-18 21:37:57 +08:00
离散序列结构在插入和删除上省时间,在随机访问上花费时间。

lru 并不需要随机访问,删除倒是很频繁。
hitmanx
2016-08-19 11:55:01 +08:00
有没有比较过两者的效率?可以写个测试 perf 一下。倒是很多在直觉上应该由链表完成的东西,在实际 os 内核的实现里用的都是 array ,就是因为局部性原理带来的效率提升。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/300139

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX