当前位置: 首页 > wzjs >正文

白天做彩票维护的网站中国营销网

白天做彩票维护的网站,中国营销网,网络搭建难吗,最棒的网站建设LRU缓存是一种满足最近最少使用约束的数据结构。我们可以用一个简单的例子来理解:假设你有一摞书,最多只能放capacity本。当你需要找一本书时,如果书在摞中,就返回它的版本(即key-value);如果不…

        LRU缓存是一种满足最近最少使用约束的数据结构。我们可以用一个简单的例子来理解:假设你有一摞书,最多只能放capacity本。当你需要找一本书时,如果书在摞中,就返回它的版本(即key-value);如果不在,就返回-1。当你想放入一本新书时,如果这本书已经存在,就更新它的版本号;如果不存在,就把新书放在最上面。如果书的数量超过了capacity,就把最下面那本书移出。

                                                        

        那么,在这个例子中,我们主要用到了哪些操作呢?又该用什么数据结构来实现呢?由于题目要求get()和put()的时间复杂度为O(1),并且需要同时存放key-value,还要删除最久未使用的元素,因此可以使用双向链表来解决。具体来说,我们主要用到了以下操作:

        1.删除

        将一个节点删除

        2.将节点放在最前面

 

        3.快速找出要找的节点

        使用哈希表,用key与节点作映射

 

class Node {
public:int key;int value;Node *prev;Node *next;Node(int k = 0,int v = 0):key(k),value(v){};
};class LRUCache {
public:int capacity = 0;Node *dummy;unordered_map<int,Node*> key_to_node;//删除节点void remove(Node *x) {x->prev->next = x->next;x->next->prev = x->prev;}//将节点放在最前void push_front(Node *x) {x->prev = dummy;x->next = dummy->next;x->next->prev = x;x->prev->next = x;}//获取节点Node* getNode(int key) {auto it = key_to_node.find(key);if (it == key_to_node.end()) {return nullptr;}Node *node = key_to_node[key];remove(node);push_front(node);return node;}LRUCache(int capacity) : capacity(capacity),dummy(new Node()) {dummy->next = dummy;dummy->prev = dummy;}int get(int key) {Node *node = getNode(key);return node ? node->value : -1;}void put(int key, int value) {Node *node = getNode(key);if (node) {node->value = value;return;}key_to_node[key] = node = new Node(key,value);push_front(node);if (capacity < key_to_node.size()) {//最久未使用节点Node *back_node = dummy->prev;key_to_node.erase(back_node->key);remove(back_node);//释放内存delete back_node;}}
};

        时间复杂度:O(1)

        空间复杂度:O(min(p,capacity),p为put的次数

http://www.dtcms.com/wzjs/156849.html

相关文章:

  • wordpress 瀑布流加载seo优化排名教程百度技术
  • 怎么压缩网站南宁seo优化
  • 为第三方网站做推广湖南网站推广
  • 官方商城下载google seo整站优化
  • 进口彩妆做的好的网站百度网登录入口
  • 网站建设 个人服务器绍兴seo公司
  • 南阳做网站 汉狮公司搜索引擎优化的目的是
  • 网站建设与管理维护中国万网登录入口
  • 网站seo 文章转载 修改标题安阳企业网站优化外包
  • 西昌网站建设上海站群优化公司
  • 如何做免费网站今日国际新闻头条新闻
  • 深圳社保个人网页登录苏州网站关键词优化推广
  • 时时彩做假网站怎么做收录排名好的发帖网站
  • 做网站服务器多少钱新闻发稿公司
  • 萍乡网站制作公司大侠seo外链自动群发工具
  • 东阳建设网站360搜索引擎网址
  • 报纸做垂直门户网站百度推广后台登录首页
  • 济南网站优化培训百度快速排名软件
  • 常州网站建设费用美国搜索引擎浏览器
  • 商城网站页面设计百度指数的特点
  • 深圳建设公司网站做百度推广员赚钱吗
  • 网站建设服务费是否无形资产深圳优化公司样高粱seo
  • 怎么做自己的微信网站百度云网盘
  • 冻品网站建设佛山快速排名seo
  • 网站内容建设流程seo排名影响因素主要有
  • 深圳网站制作功能天津百度快照优化公司
  • 网站建设奖项单页网站制作教程
  • 机械毕业设计代做网站广州网站建设技术外包
  • 做视频找素材的网站校园推广
  • 做网站是否要备案59软文网