python中怎样实现LFU算法,过程是什么
Admin 2022-08-19 群英技术资讯 1269 次浏览
这篇文章将为大家详细讲解有关“python中怎样实现LFU算法,过程是什么”的知识,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。本文实例为大家分享了python实现LFU算法的具体代码,供大家参考,具体内容如下
在第一节中实现了双向链表DoubleLinkedList类,上一节中基于双向链表实现了LRU算法,本节课我们继续基于双向链表实现LFU(Least frequently used 最不经常使用)算法。
构建LFUNode类 继承自第一节中的Node类,添加freq属性用来表示节点使用频率
class LFUNode(Node): def __init__(self, key, value): """ LFU节点 增加频率属性 :param key: :param value: """ self.freq = 0 super(LFUNode, self).__init__(key, value)
LFU的实现除了get和put之外还有一个私有的__update_freq更新节点频率方法,读写某节点时都需要对该节点的频率属性进行更新。除了map之外新增加一个freq_map来存储每个频率下的双向链表,当达到最大容量时移除最小频率下的头部的节点。
class LFUCache(object):
def __init__(self, capacity=0xffffffff):
"""
LFU缓存置换算法 最不经常使用
:param capacity:
"""
self.capacity = capacity
self.size = 0
self.map = {}
self.freq_map = {}
def __update_freq(self, node):
"""
更新节点频率
:param node:
:return:
"""
freq = node.freq
# 当前节点所在频率存在 在当前频率链表中移除当前节点
if freq in self.freq_map:
node = self.freq_map[freq].remove(node)
# 当前频率链表为空时删除该频率链表
if self.freq_map[freq].size == 0:
del self.freq_map[freq]
# 将节点按照新频率写入频率链表
freq += 1
node.freq = freq
if freq not in self.freq_map:
self.freq_map[freq] = DoubleLinkedList()
self.freq_map[freq].append(node)
return node
def get(self, key):
"""
获取元素
:return:
"""
# 节点不存在
if key not in self.map:
return None
# 节点存在 更新使用频率
old_node = self.map.get(key)
new_node = self.__update_freq(old_node)
self.map[key] = new_node
return new_node.value
def put(self, key, value):
"""
设置元素
:param key:
:param value:
:return:
"""
# 节点已存在 更新频率
if key in self.map:
old_node = self.map.get(key)
old_node.value = value
new_node = self.__update_freq(old_node)
self.map[key] = new_node
else:
# 节点容量达到上限 移除最小频率链表头部的节点
if self.size >= self.capacity:
min_freq = min(self.freq_map)
node = self.freq_map[min_freq].pop()
del self.map[node.key]
self.size -= 1
# 构建新的节点 更新频率
new_node = LFUNode(key, value)
new_node = self.__update_freq(new_node)
self.map[key] = new_node
self.size += 1
return new_node
def print(self):
"""
打印当前链表
:return:
"""
for freq, link in self.freq_map.items():
print("frequencies: %d" % freq)
link.print()
if __name__ == '__main__': lfu_cache = LFUCache(4) lfu_cache.put(1, 1) lfu_cache.print() lfu_cache.put(2, 2) lfu_cache.print() print(lfu_cache.get(1)) lfu_cache.print() lfu_cache.put(3, 3) lfu_cache.print() lfu_cache.put(4, 4) lfu_cache.print() lfu_cache.put(5, 5) lfu_cache.print() print(lfu_cache.get(2)) lfu_cache.put(4, 400) lfu_cache.print()
测试结果:

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
集合(set)是一个无序的不重复元素序列。因此在每次运行的时候集合的运行结果的内容都是相同的,但元素的排列顺序却不是固定的,所以本章中部分案例的运行结果会出现与给出结果不同的情况(运行结果不唯一)可以使用大括号{}或者set()函数创建集合,注意:创建一个空集合必须用set()而不是{},因为{}是用来创建一个空字典
在给计算机编程时,经常需要将数据告诉计算机,会将二进制数直接输入计算机, 但二进制数的特点是,只有0和1两种记数,位数比较长。如果用二进制数写程序,只要这个数比较大, 位数就会很长,很容易写错,同时二进制并不直观,写出来的数是否正确,需要转换才能知道。
这篇文章主要介绍了使用python tkinter实现各种个样的撩妹鼠标拖尾效果,本文通过实例代码,给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
在日常服务器运维工作中,备份数据库是必不可少的,刚工作那会看到公司都是用shell脚本循环备份数据库,到现在自己学习python语言后,利用多进程多线程相关技术来实现并行备份数据库,充分利用服务器资源,提高备份速度。
在开发自用爬虫过程中,有的网页是utf-8,有的是gb2312,有的是gbk,如果不加处理,采集到的都是乱码,解决的方法是将html处理成统一的utf-8
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008