您的位置:首页 > 其它

算法: 实现LRU缓存,读取、写入O(1)实现

2017-10-17 08:07 316 查看
这题应该见的不少了,写写记录一下。

实现该功能分析:

(1) O(1) 时间完成查找,那除了 hash 别无选择。

(2) LRU 最近最少使用算法,为了方便数据的淘汰。需要对最近访问的数据放未访问数据之前。

用双向链表实现即可。(通常情况下,双向链表读取、插入的时间复杂度都是O(n), 但是如果知道插入位置,则可以实现O(1)实现。)

实现: hash存key对应的数据在双向链表中的位置,就可以完成该功能。

具体代码:

1 #include <iostream>
2 #include <list> //std::list双向链表实现
3 #include <map>
4
5 const int MAX_VALUE_LEN = 32;
6 const int MAX_ELEMENT_NUM = 3;
7
8 struct CacheNode{
9     int key;
10     int len;
11     char data[MAX_VALUE_LEN];
12 };
13
14 class LRU{
15 public:
16     //默认10个原始
17     LRU(int max_num = MAX_ELEMENT_NUM);
18     ~LRU();
19
20     //数据获取
21     bool get(const int key, char *data, int &len);
22
23     //新增数据
24     bool set(const int key, const char* data, const int len);
25
26     //打印数据
27     void print_list();
28 private:
29
30     //更新节点的链接
31     //访问元素后, 需要将元素放置在list 头部
32     int update_node_link(const int key);
33
34     int _max_num;
35     std::list<CacheNode*> _list;
36     std::map<int, std::list<CacheNode*>::iterator> _map;
37 };
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: