Leetcode Solutions Java Python C++
All contents and pictures on this website come from the Internet and are updated regularly every week. They are for personal study and research only, and should not be used for commercial purposes. Thank you for your cooperation.
Welcome to Subscribe On Youtube:

146. LRU Cache

Design and implement a data structure for Least Recently Used (LRU) cache. It should support the following operations: get and put.

get(key) - Get the value (will always be positive) of the key if the key exists in the cache, otherwise return -1.
put(key, value) - Set or insert the value if the key is not already present. When the cache reached its capacity, it should invalidate the least recently used item before inserting a new item.

The cache is initialized with a positive capacity.

Follow up:
Could you do both operations in O(1) time complexity?

Example:

LRUCache cache = new LRUCache( 2 /* capacity */ );

cache.put(1, 1);
cache.put(2, 2);
cache.get(1);       // returns 1
cache.put(3, 3);    // evicts key 2
cache.get(2);       // returns -1 (not found)
cache.put(4, 4);    // evicts key 1
cache.get(1);       // returns -1 (not found)
cache.get(3);       // returns 3
cache.get(4);       // returns 4

 

Difficulty:

Medium

Lock:

Normal

Company:

Adobe Affirm Alibaba Amazon Apple Asana Baidu Bloomberg ByteDance Cisco Citadel Cloudera Cruise Automation DoorDash Dropbox eBay Expedia Facebook GoDaddy Goldman Sachs Google Groupon HBO Intuit caMorgan LinkedIn Lyft Microsoft Morgan Stanley Nutanix Nvidia Oracle Palantir Technologies Paypal Pinterest Roblox Salesforce SAP Snapchat Splunk Spotify Tesla TripAdvisor Twilio Twitch Twitter Two Sigma Uber Visa VMware Walmart Labs Wish Yahoo Yandex Zenefits Zillow

Problem Solution

146-LRU-Cache

All Problems:

Link to All Problems
All contents and pictures on this website come from the Internet and are updated regularly every week. They are for personal study and research only, and should not be used for commercial purposes. Thank you for your cooperation.