package LRU;
/*
不使用LinkedListMap實(shí)現(xiàn)
*/
import java.util.HashMap;
import java.util.LinkedHashMap;
class Node{
public int key, val;
public Node pre, next;
public Node(int k, int v){
this.key = k;
this.val = v;
}
}
class DoubleList{
private Node head, tail;
private int size;
public DoubleList(){
head = new Node(0,0);
tail = new Node(0,0);
head.next = tail;
tail.pre = head;
size = 0;
}
//添加結(jié)點(diǎn)至隊(duì)尾
public void addLast(Node x){
x.pre = tail.pre;
x.next = tail;
tail.pre.next = x;
tail.pre = x;
size++;
}
//刪除目標(biāo)結(jié)點(diǎn)
public void remove(Node x){
x.pre.next = x.next;
x.next.pre = x.pre;
size--;
}
//刪除鏈表中第一個(gè)結(jié)點(diǎn)并返回
public Node removeFirst(){
if(head==null){
return null;
}else{
Node first = head.next;
remove(first);
return first;
}
}
//時(shí)間復(fù)雜度為1
public int size(){
return size;
}
}
public class LRUCacheEssential {
private HashMap<Integer, Node> map ;
private DoubleList cache ;
private int cap;
public LRUCacheEssential(int cap){
this.cap = cap;
map = new LinkedHashMap<>();
cache = new DoubleList();
}
//將某個(gè)key提升為最近使用
private void makeRecently(int key){
Node x = map.get(key);
cache.remove(x);
cache.addLast(x);
}
//添加最近使用的元素
private void addRecently(int key, int val){
Node x = new Node(key,val);
cache.addLast(x);
map.put(key, x);
System.out.println("成功添加"+key+","+map.get(key).val);
}
//刪除一個(gè)key
private void deleteKey(int key){
Node x = map.get(key);
cache.remove(x);
map.remove(key);
}
//刪除最久沒有使用的
private void removeLeastRecently(){
Node x=cache.removeFirst();
map.remove(x.key);
System.out.println("刪除數(shù)據(jù)"+x.key);
}
public int get(int key){
if(!map.containsKey(key)){
return -1;
}
makeRecently(key);
return map.get(key).val;
}
public void put(int key, int val){
if(map.containsKey(key)){
deleteKey(key);
addRecently(key,val);
System.out.println("更改數(shù)據(jù)");
return;
}
if(cap == cache.size()){
removeLeastRecently();
}
addRecently(key,val);
}
public static void main(String[] args) {
LRUCacheEssential lru = new LRUCacheEssential(5);
lru.put(0,1);
lru.put(1,1);
lru.put(2,1);
lru.put(3,1);
lru.put(4,1);
lru.put(5,1);
lru.put(2,3);
lru.put(0,1);
}
}
LRU算法實(shí)現(xiàn)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
- 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來其馏,“玉大人凤跑,你說我怎么就攤上這事∨迅矗” “怎么了仔引?”我有些...
- 文/不壞的土叔 我叫張陵,是天一觀的道長褐奥。 經(jīng)常有香客問我咖耘,道長,這世上最難降的妖魔是什么撬码? 我笑而不...
- 正文 為了忘掉前任儿倒,我火速辦了婚禮,結(jié)果婚禮上呜笑,老公的妹妹穿的比我還像新娘夫否。我一直安慰自己彻犁,他們只是感情好,可當(dāng)我...
- 文/花漫 我一把揭開白布凰慈。 她就那樣靜靜地躺著汞幢,像睡著了一般。 火紅的嫁衣襯著肌膚如雪溉瓶。 梳的紋絲不亂的頭發(fā)上急鳄,一...
- 文/蒼蘭香墨 我猛地睜開眼哼绑,長吁一口氣:“原來是場噩夢啊……” “哼岩馍!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
- 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎朋魔,沒想到半個(gè)月后锋恬,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
- 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
- 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片顽馋。...
- 正文 年R本政府宣布熊痴,位于F島的核電站,受9級特大地震影響聂宾,放射性物質(zhì)發(fā)生泄漏愁拭。R本人自食惡果不足惜,卻給世界環(huán)境...
- 文/蒙蒙 一亏吝、第九天 我趴在偏房一處隱蔽的房頂上張望岭埠。 院中可真熱鬧,春花似錦、人聲如沸惜论。這莊子的主人今日做“春日...
- 文/蒼蘭香墨 我抬頭看了看天上的太陽馆类。三九已至混聊,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間乾巧,已是汗流浹背句喜。 一陣腳步聲響...
- 正文 我出身青樓,卻偏偏與公主長得像旷太,于是被迫代替她去往敵國和親展懈。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
推薦閱讀更多精彩內(nèi)容
- 一供璧、redis的緩存淘汰策略 1存崖、redis的緩存淘汰策略回收策略 noeviction:返回錯(cuò)誤當(dāng)內(nèi)存限制達(dá)到并...
- 本文主要介紹了Nodejs基于LRU算法實(shí)現(xiàn)的緩存處理操作,結(jié)合具體實(shí)例形式分析了LRU算法的原理、功能以及n...
- LRU算法睡毒,實(shí)現(xiàn)了put来惧,remove(int),remove()演顾,setMaxLength(int)四種方法供搀。 ...
- Android用LruCache(Least recently use Cache 意思就是最近使用次數(shù)最少的那...
- 本文首發(fā)于 LOGI'S BLOG,由作者轉(zhuǎn)載偶房。 在使用頁進(jìn)行內(nèi)存管理的操作系統(tǒng)中,當(dāng)新頁進(jìn)入內(nèi)存且內(nèi)存已滿時(shí)军浆,需...