如何用Python实现FIFO置换算法,方法是什么
Admin 2022-08-19 群英技术资讯 467 次浏览
本文实例为大家分享了Python实现FIFO缓存置换算法的具体代码,供大家参考,具体内容如下
在上一节中我们实现了双向链表DoubleLinkedList类,本节我们基于双向链表实现FIFO(先进先出)缓存置换算法。
代码逻辑很简单,就是遵循先进先出的原则,具体流程都写在注释中了。通过一个map来实现查找时的O(1)复杂度
class FIFOCache(object): def __init__(self, capacity=0xffffffff): """ FIFO缓存置换算法 :param capacity: """ self.capacity = capacity self.map = {} self.size = 0 self.list = DoubleLinkedList(capacity) def get(self, key): """ 获取元素 不存在 返回None 已存在 则返回缓存值 :param key: :return: """ # 当前缓存中不存在 if key not in self.map: return None # 当前缓存中存在 node = self.map.get(key) return node.value def put(self, key, value): """ 添加元素 已存在 更新值并添加至链表尾部 不存在 判断缓存容量大小后添加 :param key: :param value: :return: 已添加的节点 """ # 当前缓存中已存在 if key in self.map: node = self.map.get(key) self.list.remove(node) node.value = value self.list.append(node) else: # 缓存容量达到上限 删除头结点 if self.size >= self.capacity: old_node = self.list.pop() del self.map[old_node.key] self.size -= 1 node = Node(key, value) self.map[key] = node self.list.append(node) self.size += 1 return node def print(self): """ 打印当前链表 :return: """ self.list.print() # print(self.map)
if __name__ == '__main__': fifo_cache = FIFOCache(2) fifo_cache.put(1, 1) fifo_cache.print() fifo_cache.put(2, 2) fifo_cache.print() print(fifo_cache.get(2)) fifo_cache.put(3, 3) fifo_cache.print() print(fifo_cache.get(1)) fifo_cache.put(2, 4) fifo_cache.print()
测试结果:
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
Python基本数据类型一般分为:数字、字符串、列表、元组、字典、集合这六种基本数据类型。浮点型、复数类型、布尔型(布尔型就是只有两个值的整型)、这几种数字类型。列表、元组、字符串都是序列。
这篇文章主要为大家详细介绍了python实现人人对战的五子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
接触过Java的朋友对于类应该不陌生,我们在学习python过程中,也会学习到类,那么python的类如何理解?很多新手学习python时,可能对此比较困惑。对此,下面小编就给大家介绍一下python的类以及使用。感兴趣的朋友就继续往下看吧。
使用python怎样实现图片反转效果?很多朋友对于怎样做图片和视频的反转效果比较感兴趣,其实实现思路并不困难,这篇文章就给大家分享一下python实现图片和视频反转效果的代码,感兴趣的朋友可以参考。
这篇文章主要介绍了Python数据结构列表,本文重点内容主要是对列表数据结构的使用,在Python中,序列是一组按顺序排列的值。Python 有 3 种内置的序列类型:字符串、 元组和列表,下面一起进入文章了解更详细内容吧,需要的小伙伴可以参考一下</P><P>
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008