C++实现LRU缓存——LeetCode146

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C++实现LRU缓存——LeetCode146相关的知识,希望对你有一定的参考价值。

参考技术A list的常见方法:

begin(): 返回第一个元素的迭代器
end(): 最后一个元素的下一个位置的迭代器
front(): 第一个元素的引用
back(): 最后一个元素的引用
emplace_front(), emplace_back() : 头部,尾部生成一个元素,比push_back效率高
push_back(), pop_back(): 尾部插入、删除一个元素
splice(): 将一个 list 容器中的元素插入到另一个容器的指定位置

Leetcode No.146 LRU 缓存机制

一、题目描述

运用你所掌握的数据结构,设计和实现一个  LRU (最近最少使用) 缓存机制 。
实现 LRUCache 类:

LRUCache(int capacity) 以正整数作为容量 capacity 初始化 LRU 缓存
int get(int key) 如果关键字 key 存在于缓存中,则返回关键字的值,否则返回 -1 。
void put(int key, int value) 如果关键字已经存在,则变更其数据值;如果关键字不存在,则插入该组「关键字-值」。当缓存容量达到上限时,它应该在写入新数据之前删除最久未使用的数据值,从而为新的数据值留出空间。
 

进阶:你是否可以在 O(1) 时间复杂度内完成这两种操作?

示例:

输入
["LRUCache", "put", "put", "get", "put", "get", "put", "get", "get", "get"]
[[2], [1, 1], [2, 2], [1], [3, 3], [2], [4, 4], [1], [3], [4]]
输出
[null, null, null, 1, null, -1, null, -1, 3, 4]

解释
LRUCache lRUCache = new LRUCache(2);
lRUCache.put(1, 1); // 缓存是 {1=1}
lRUCache.put(2, 2); // 缓存是 {1=1, 2=2}
lRUCache.get(1);    // 返回 1
lRUCache.put(3, 3); // 该操作会使得关键字 2 作

以上是关于C++实现LRU缓存——LeetCode146的主要内容,如果未能解决你的问题,请参考以下文章

leetcode146. LRU缓存机制

LeetCode第146题—LRU缓存机制—Python实现

LeetCode 146. LRU 缓存

LeetCode 146. LRU 缓存机制

Leetcode No.146 LRU 缓存机制

LeetCode #146 LRU缓存机制