24. LFU缓存

24. LFU缓存

LFU是一个著名的缓存算法

对于容量为k的缓存,如果缓存已满,并且需要逐出其中的密钥,则最少使用的密钥将被踢出。

实现LFU中的set 和 get

样例

输入:

LFUCache(3)

set(2,2)

set(1,1)

get(2)

get(1)

get(2)

set(3,3)

set(4,4)

get(3)

get(2)

get(1)

get(4)

 

输出:

2

1

2

-1

2

1

4

public class LFUCache {


        class Cache {
            int val;
            long lastTime;
            int useNumber;


             Cache(int val, long lastTime, int useNumber) {
                this.val = val;
                this.lastTime = lastTime;
                this.useNumber = useNumber;
            }
        }


        HashMap<Integer, Cache> numArray;
        int size;
        /*
         * @param capacity: An integer
         */
        public LFUCache(int capacity) {
            // do intialization if necessary
            size = capacity;
            numArray = new HashMap<>(capacity*2, 0.75f);
        }




        /*
         * @param key: An integer
         * @param value: An integer
         * @return: nothing
         */
        public void set(int key, int value) {
            // write your code here
            if (numArray.containsKey(key)) {
                changList(key,value);
            } else {
                if (numArray.size() >= size) {
                    delete();
                }
                Cache cache = new Cache(value, System.nanoTime(), 0);
                numArray.put(key, cache);
            }
        }




        /*
         * @param key: An integer
         * @return: An integer
         */
        public int get(int key) {
            // write your code here
            if (numArray.containsKey(key)) {
                int val=numArray.get(key).val;
                changList(key,val);
                return val;
            } else {
                return -1;
            }
        }




        private void delete() {
            int minCount = Integer.MAX_VALUE;
            long getTime = System.nanoTime();
            int t = 0;
            for (int key : numArray.keySet()) {
                Cache node = numArray.get(key);
                if (node.useNumber < minCount || (node.useNumber == minCount && node.lastTime < getTime)) {
                    t = key;
                    minCount = node.useNumber;
                    getTime = node.lastTime;
                }
            }
            numArray.remove(t);
        }




        private void changList(int key,int value) {
            Cache cache = numArray.get(key);
            if (cache != null) {
                cache.val=value;
                cache.useNumber++;
                cache.lastTime = System.nanoTime();
                // numArray.put(key, cache);
            }
        }
    }

这题难点在于对LFU的理解,一个是次数,还有一个是时间,时间非常容易被忽略,记得加上纳秒级的差距判断,这样比较有效。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

时代我西

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值