国产亚洲精品福利在线无卡一,国产精久久一区二区三区,亚洲精品无码国模,精品久久久久久无码专区不卡

當(dāng)前位置: 首頁 > news >正文

腐女做喜歡的網(wǎng)站做銷售記住這十句口訣

腐女做喜歡的網(wǎng)站,做銷售記住這十句口訣,餐飲網(wǎng)站開發(fā)畢業(yè)設(shè)計(jì),合肥網(wǎng)站建設(shè)外包題目描述 請你設(shè)計(jì)并實(shí)現(xiàn)一個(gè)滿足 LRU (最近最少使用) 緩存 約束的數(shù)據(jù)結(jié)構(gòu)。 實(shí)現(xiàn) LRUCache 類: LRUCache(int capacity) 以 正整數(shù) 作為容量 capacity 初始化 LRU 緩存 int get(int key) 如果關(guān)鍵字 key 存在于緩存中,則返回關(guān)鍵字的值,否則…

題目描述
請你設(shè)計(jì)并實(shí)現(xiàn)一個(gè)滿足 LRU (最近最少使用) 緩存 約束的數(shù)據(jù)結(jié)構(gòu)。
實(shí)現(xiàn) LRUCache 類:
LRUCache(int capacity) 以 正整數(shù) 作為容量 capacity 初始化 LRU 緩存
int get(int key) 如果關(guān)鍵字 key 存在于緩存中,則返回關(guān)鍵字的值,否則返回 -1 。
void put(int key, int value) 如果關(guān)鍵字 key 已經(jīng)存在,則變更其數(shù)據(jù)值 value ;如果不存在,則向緩存中插入該組 key-value 。如果插入操作導(dǎo)致關(guān)鍵字?jǐn)?shù)量超過 capacity ,則應(yīng)該 逐出 最久未使用的關(guān)鍵字。
函數(shù) get 和 put 必須以 O(1) 的平均時(shí)間復(fù)雜度運(yùn)行。

示例
示例:
輸入
[“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); // 該操作會使得關(guān)鍵字 2 作廢,緩存是 {1=1, 3=3}
lRUCache.get(2); // 返回 -1 (未找到)
lRUCache.put(4, 4); // 該操作會使得關(guān)鍵字 1 作廢,緩存是 {4=4, 3=3}
lRUCache.get(1); // 返回 -1 (未找到)
lRUCache.get(3); // 返回 3
lRUCache.get(4); // 返回 4

解題思想
1、使用雙向鏈表
2、使用HashMap
將最近使用的放到鏈表頭部,如果超過容量就將最尾部的刪除掉。

代碼

class LRUCache {
public://定義雙向鏈表struct Node {int key, val;Node* next, * prev;Node(): key(0), val(0), prev(nullptr), next(nullptr){};Node(int _key,int _val):key(_key),val(_val), prev(nullptr), next(nullptr) {};};//鏈表的首尾節(jié)點(diǎn)Node* head, *tail;//key和結(jié)點(diǎn)的映射關(guān)系unordered_map<int, Node*> umap;int capacity,size; //容量大小和已經(jīng)使用的大小LRUCache(int capacity) {//初始化this->capacity = capacity;this->size = 0;head = new Node();tail = new Node();head->next = tail;tail->prev = head;}int get(int key) {//如果不存在返回-1if (!umap.count(key))return -1;Node* node = umap[key];removeNode(node);addNodeToHead(node);return node->val;}void put(int key, int value) {//如果鏈表中key存在,就修改value的值,然后再插入到表頭if (umap.count(key)) {Node* node = umap[key];node->val = value;removeNode(node);addNodeToHead(node);}//如果不存在else {//如果容量不夠,就先刪除最久未使用的,然后再創(chuàng)建一個(gè)新的結(jié)點(diǎn)if (capacity == size) {Node* removed = tail->prev;//從哈希表中刪除最久未訪問的umap.erase(removed->key);//從鏈表中也刪除removeNode(removed);size--;}//新創(chuàng)建一個(gè)節(jié)點(diǎn)Node* node = new Node(key, value);addNodeToHead(node);umap[key] = node;size++;}}//刪除當(dāng)前節(jié)點(diǎn)void removeNode(Node* node) {node->prev->next = node->next;node->next->prev = node->prev;}//添加到表頭void  addNodeToHead(Node* node) {node->prev = head;node->next = head->next;head->next->prev = node;head->next = node;}
};
http://aloenet.com.cn/news/28803.html

相關(guān)文章:

  • 哪些網(wǎng)站可以做簽約設(shè)計(jì)師在線crm網(wǎng)站建站
  • wix建設(shè)網(wǎng)站鏈接交換平臺
  • 淘寶客做網(wǎng)站教程網(wǎng)站注冊信息查詢
  • 建設(shè)網(wǎng)站的方案抖音競價(jià)推廣怎么做
  • 兼職做ps網(wǎng)站百度網(wǎng)盤搜索引擎網(wǎng)站
  • wordpress 所有鉤子商丘seo公司
  • 大型的網(wǎng)站開發(fā)crm系統(tǒng)網(wǎng)站
  • 免費(fèi)網(wǎng)站制作效果百度一下你就知道123
  • 邯鄲做移動網(wǎng)站費(fèi)用seo專業(yè)論壇
  • 網(wǎng)站網(wǎng)速慢刷百度關(guān)鍵詞排名
  • 瑞安做網(wǎng)站建設(shè)湖南網(wǎng)站建設(shè)seo
  • 桐鄉(xiāng)做網(wǎng)站正規(guī)seo大概多少錢
  • 網(wǎng)站不兼容怎么辦鄭州seo博客
  • 網(wǎng)站內(nèi)容全屏截屏怎么做網(wǎng)站做seo教程
  • 自己站網(wǎng)站如何進(jìn)行搜索引擎優(yōu)化
  • 查法人信息的網(wǎng)站培訓(xùn)計(jì)劃和培訓(xùn)內(nèi)容
  • 建網(wǎng)站要花錢嗎seo如何建立優(yōu)化網(wǎng)站
  • 上海網(wǎng)站建設(shè)定制公司谷歌推廣代理公司
  • 用wordpress怎么做網(wǎng)站免費(fèi)s站推廣網(wǎng)站
  • 濰坊網(wǎng)站建設(shè)客服代寫文章質(zhì)量高的平臺
  • 電子商務(wù)網(wǎng)站開發(fā)是什么官方正版清理優(yōu)化工具
  • cnzz網(wǎng)站建設(shè)廣州seo好找工作嗎
  • 廣州家居網(wǎng)站設(shè)計(jì)nba最新交易匯總
  • 大學(xué)生想做網(wǎng)站西安seo優(yōu)化推廣
  • 青島網(wǎng)站建設(shè)小公司seo綜合查詢工具
  • 網(wǎng)站是否必須做可信網(wǎng)站認(rèn)證seo自動優(yōu)化軟件下載
  • 訂房網(wǎng)站開發(fā)長春網(wǎng)站建設(shè)推廣
  • 網(wǎng)站開發(fā)驗(yàn)收單8大營銷工具指的是哪些
  • 怎么做提卡密網(wǎng)站域名解析網(wǎng)站
  • 專注做一家男人最愛的網(wǎng)站廣州seo運(yùn)營