-
Notifications
You must be signed in to change notification settings - Fork 517
/
Copy pathCache System Using LRU Algorithm.py
63 lines (55 loc) · 2.71 KB
/
Cache System Using LRU Algorithm.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
class LRUCache:
def __init__(self, capacity: int):
"""
Initialize the cache with a given capacity.
- `cache`: Dictionary to store key-value pairs.
- `order`: List to maintain the order of key access (most recent key will be at the end).
"""
self.cache = {} # Dictionary to store cache items (key-value pairs)
self.capacity = capacity # Maximum capacity of the cache
self.order = [] # List to keep track of the order of keys based on usage
def get(self, key: int) -> int:
"""
Fetch the value associated with the key if it exists in the cache.
If key is found, update its position as the most recently used key.
If key is not found, return -1.
"""
if key in self.cache:
# Remove the key from its current position and move it to the end (most recently used)
self.order.remove(key)
self.order.append(key)
return self.cache[key] # Return the corresponding value
return -1 # Key not found in cache
def put(self, key: int, value: int) -> None:
"""
Insert a new key-value pair into the cache.
If the key already exists, update its value and move it to the most recently used position.
If the cache reaches its capacity, remove the least recently used (LRU) item.
"""
if key in self.cache:
# If the key is already in cache, update its position in the order
self.order.remove(key)
elif len(self.cache) == self.capacity:
# Cache is full, remove the least recently used item (oldest key)
oldest_key = self.order.pop(0)
del self.cache[oldest_key]
# Add/update the cache with the new key-value pair and mark it as the most recently used
self.cache[key] = value
self.order.append(key)
# Test Cases
lru_cache = LRUCache(2)
# Test Case 1: Fetching a non-existent key
print(lru_cache.get(1)) # Output: -1 (key 1 not found)
# Test Case 2: Adding two entries and fetching them
lru_cache.put(1, 1) # Add key 1 with value 1
lru_cache.put(2, 2) # Add key 2 with value 2
print(lru_cache.get(1)) # Output: 1 (key 1 is found)
# Test Case 3: Adding a third entry which will evict the least recently used item (key 2)
lru_cache.put(3, 3) # Add key 3, evicts key 2
print(lru_cache.get(2)) # Output: -1 (key 2 is evicted)
# Test Case 4: Fetching the existing key and adding a new one
print(lru_cache.get(3)) # Output: 3 (key 3 is found)
lru_cache.put(4, 4) # Add key 4, evicts key 1
print(lru_cache.get(1)) # Output: -1 (key 1 is evicted)
print(lru_cache.get(3)) # Output: 3 (key 3 is still present)
print(lru_cache.get(4)) # Output: 4 (key 4 is found)