146 LRU缓存

python 复制代码
class DLinkedList:

    def __init__(self, key = 0, val = 0):
        self.prev = None
        self.next = None
        self.val = val
        self.key = key

class LRUCache:

    def __init__(self, capacity: int):
        self.head = DLinkedList()
        self.tail = DLinkedList()
        self.head.next = self.tail
        self.tail.prev = self.head
        self.cache = {}
        self.capacity = capacity

    def get(self, key: int) -> int:
        if key in self.cache:
            node = self.cache[key]
            self.remove(node)
            self.movetoHead(node)
            return self.cache[key].val
        
        return -1


    def put(self, key: int, value: int) -> None:
        if key in self.cache:
            node = self.cache[key]
            node.val = value
            self.remove(node)
            self.movetoHead(node)
        else:

            if self.capacity == 0:
                del self.cache[self.tail.prev.key]
                self.remove(self.tail.prev)
                self.capacity += 1

            node = DLinkedList(key,value)
            self.cache[key] = node
            self.capacity -= 1
            self.movetoHead(node)

            
    
    def movetoHead(self, node):
        tmp = self.head.next
        self.head.next = node
        node.prev = self.head
        node.next = tmp
        tmp.prev = node

    def remove(self, node):
        prev = node.prev
        next = node.next
        prev.next = next
        next.prev = prev

重点:

操作模块化(remove, movetoHead);

双向链表,链表内保存key - value;

虚拟头尾节点。

相关推荐
此生只爱蛋12 分钟前
【Redis】数据类型补充
数据库·redis·缓存
在风中的意志12 分钟前
[数据库SQL] [leetcode-584] 584. 寻找用户推荐人
数据库·sql·leetcode
毅炼16 分钟前
hot100打卡——day08
java·数据结构·算法·leetcode·深度优先
AI手记叨叨29 分钟前
Python数学:几何运算
python·数学·解析几何·射影几何·微分几何·欧几里得几何
toolhow1 小时前
SelfAttenion自注意力机制
pytorch·python·深度学习
智航GIS1 小时前
6.2 while循环
java·前端·python
qq_336313931 小时前
java基础-IO流(转换流)
java·开发语言·python
Stestack1 小时前
ssh批量机器免密操作
linux·python·ssh
a程序小傲1 小时前
得物Java面试被问:反射机制的原理和应用场景
java·python·面试
于越海1 小时前
学习小项目:用 Python 自动统计编程课绩点(5.0 制|百分制直算|重修取最高)
开发语言·笔记·python·学习·学习方法