LRU/LFU
146. LRU Cache
class Node:
def __init__(self, key=0, val=0):
self.key = key
self.val = val
self.prev = None
self.next = None
class LRUCache:
def __init__(self, capacity: int):
self.hash = {}
self.count = 0
self.capacity = capacity
self.head, self.tail = Node(), Node()
self.head.next = self.tail
self.tail.prev = self.head
def moveToHead(self, node):
node.next = self.head.next
node.next.prev = node
self.head.next = node
node.prev= self.head
def removeNode(self, node):
node.next.prev = node.prev
node.prev.next = node.next
def get(self, key: int) -> int:
if key not in self.hash: return -1
node = self.hash[key]
self.removeNode(node)
self.moveToHead(node)
return node.val
def put(self, key: int, value: int) -> None:
if key in self.hash:
node = self.hash[key]
node.val = value
self.removeNode(node)
self.moveToHead(node)
else:
node = Node(key, value)
self.hash[key] = node
self.moveToHead(node)
self.count +=1
if self.count > self.capacity:
self.hash.pop(self.tail.prev.key)
self.removeNode(self.tail.prev)
self.count -= 1460. LFU Cache
Last updated