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-04Maven發(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-07Maven pom的distributionManagement配置方式
文章主要介紹了Maven的distributionManagement配置方式,以及它的作用、配置方法和重要性,distributionManagement用于指定構(gòu)件的發(fā)布位置,包括下載URL、狀態(tài)等,文章還詳細(xì)解釋了如何配置repository和snapshotRepository,以及它們的用途和區(qū)別2025-01-01Java實(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-02SpringBoot使用自定義注解實(shí)現(xiàn)數(shù)據(jù)脫敏過(guò)程詳細(xì)解析
這篇文章主要介紹了SpringBoot自定義注解之脫敏注解詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02Java中類轉(zhuǎn)json的基類實(shí)現(xiàn)
這篇文章主要介紹了Java中類轉(zhuǎn)json的基類實(shí)現(xiàn),需要的朋友可以參考下2021-01-01Java的Jackson庫(kù)中復(fù)雜對(duì)象集合的幾種簡(jiǎn)單轉(zhuǎn)換
本文主要介紹了Java的Jackson庫(kù)中復(fù)雜對(duì)象集合的幾種簡(jiǎn)單轉(zhuǎn)換。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-02-02