java實(shí)現(xiàn)LFU算法的示例代碼
使用JAVA語(yǔ)言實(shí)現(xiàn)常用的LFU(Least Frequently Used)算法
定義一個(gè)LFUNode類來(lái)表示LFU緩存中的節(jié)點(diǎn)
private static class LFUNode<K, V> {
K key;
V value;
int frequency;
public LFUNode(K k, V v) {
key = k;
value = v;
frequency = 1;
}
}
接下來(lái),我們創(chuàng)建一個(gè)LFUCache類來(lái)實(shí)現(xiàn)LFU緩存。在初始化函數(shù)中,我們需要指定緩存的最大容量。
public class LFUCache1<K, V> {
private int capacity;
private Map<K, LFUNode<K, V>> cacheMap;
private Map<Integer, LinkedHashSet<LFUNode<K, V>>> frequencyMap;
private int minFrequency;
public void init(int size) {
this.capacity = size;
cacheMap = new HashMap<>();
frequencyMap = new HashMap<>();
minFrequency = 0;
}
...
接下來(lái),我們實(shí)現(xiàn)兩個(gè)輔助方法:
addToFrequencyMap:將節(jié)點(diǎn)添加到對(duì)應(yīng)頻率的鏈表中。removeFromFrequencyMap:從對(duì)應(yīng)頻率的鏈表中移除節(jié)點(diǎn)。
private void addToFrequencyMap(LFUNode<K, V> node) {
int frequency = node.frequency;
frequencyMap.putIfAbsent(frequency, new LinkedHashSet<>());
frequencyMap.get(frequency).add(node);
if (frequency == 1) {
minFrequency = 1;
}
}
private void removeFromFrequencyMap(LFUNode<K, V> node) {
int frequency = node.frequency;
frequencyMap.get(frequency).remove(node);
if (frequency == minFrequency && frequencyMap.get(frequency).size() == 0) {
minFrequency++;
}
}
最后實(shí)現(xiàn)核心方法:get和put
public V get(K key) {
if (cacheMap.containsKey(key)) {
LFUNode<K, V> node = cacheMap.get(key);
removeFromFrequencyMap(node);
node.frequency++;
addToFrequencyMap(node);
return node.value;
}
return null;
}
public void put(K key, V value) {
if (capacity <= 0) {
return;
}
if (cacheMap.containsKey(key)) {
LFUNode<K, V> node = cacheMap.get(key);
removeFromFrequencyMap(node);
node.value = value;
node.frequency++;
addToFrequencyMap(node);
} else {
if (cacheMap.size() >= capacity) {
LinkedHashSet<LFUNode<K, V>> minFrequencySet = frequencyMap.get(minFrequency);
LFUNode<K, V> evictNode = minFrequencySet.iterator().next();
minFrequencySet.remove(evictNode);
cacheMap.remove(evictNode.key);
}
LFUNode<K, V> newNode = new LFUNode<>(key, value);
cacheMap.put(key, newNode);
addToFrequencyMap(newNode);
minFrequency = 1;
}
}
最終驗(yàn)證結(jié)果如下:
@Test
public void testCase() {
LFUCache1<Integer, String> cache = new LFUCache1<>();
cache.init(2);
cache.put(1, "Hello");
cache.put(2, "World");
System.out.println(cache.get(1)); // Output: Hello
cache.put(3, "Foo");
System.out.println(cache.get(2)); // Output: null (evicted)
System.out.println(cache.get(3)); // Output: Foo
}
到此這篇關(guān)于java實(shí)現(xiàn)LFU算法的示例代碼的文章就介紹到這了,更多相關(guān)java LFU算法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Mybatis動(dòng)態(tài)sql超詳細(xì)講解
動(dòng)態(tài)SQL是MyBatis的強(qiáng)大特性之一,顧名思義就是會(huì)動(dòng)的SQL,即是能夠靈活的根據(jù)某種條件拼接出完整的SQL語(yǔ)句,下面這篇文章主要給大家介紹了關(guān)于Mybatis動(dòng)態(tài)sql的相關(guān)資料,需要的朋友可以參考下2023-04-04
Maven發(fā)布項(xiàng)目到Nexus私有服務(wù)器
本文主要介紹了Maven發(fā)布項(xiàng)目到Nexus私有服務(wù)器,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07
Maven pom的distributionManagement配置方式
文章主要介紹了Maven的distributionManagement配置方式,以及它的作用、配置方法和重要性,distributionManagement用于指定構(gòu)件的發(fā)布位置,包括下載URL、狀態(tài)等,文章還詳細(xì)解釋了如何配置repository和snapshotRepository,以及它們的用途和區(qū)別2025-01-01
Java實(shí)現(xiàn)彩色圖片轉(zhuǎn)換為灰度圖片的示例代碼
將彩色圖片轉(zhuǎn)換為灰度圖片是圖像處理中的常見(jiàn)操作,通常用于簡(jiǎn)化圖像、增強(qiáng)對(duì)比度、或者進(jìn)行后續(xù)的圖像分析,本項(xiàng)目的目標(biāo)是通過(guò)Java實(shí)現(xiàn)將彩色圖片轉(zhuǎn)換為灰度圖片,需要的朋友可以參考下2025-02-02
SpringBoot使用自定義注解實(shí)現(xiàn)數(shù)據(jù)脫敏過(guò)程詳細(xì)解析
這篇文章主要介紹了SpringBoot自定義注解之脫敏注解詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
Java中類轉(zhuǎn)json的基類實(shí)現(xiàn)
這篇文章主要介紹了Java中類轉(zhuǎn)json的基類實(shí)現(xiàn),需要的朋友可以參考下2021-01-01
Java的Jackson庫(kù)中復(fù)雜對(duì)象集合的幾種簡(jiǎn)單轉(zhuǎn)換
本文主要介紹了Java的Jackson庫(kù)中復(fù)雜對(duì)象集合的幾種簡(jiǎn)單轉(zhuǎn)換。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-02-02

