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的主要内容,如果未能解决你的问题,请参考以下文章