题解 | #设计LRU缓存结构#

设计LRU缓存结构

http://www.nowcoder.com/practice/5dfded165916435d9defb053c63f1e84

import java.util.*;


public class Solution {
    
    private LinkedHashMap<Integer, Integer> linkedHashMap;
    private int capacity;
    
    // 构造函数
    public Solution(int capacity) {
         // write code here
        this.capacity = capacity;
        linkedHashMap = new LinkedHashMap<>(capacity);
    }

    public int get(int key) {
         // write code here
        int value = linkedHashMap.getOrDefault(key, -1);
        if (value != -1) {
            linkedHashMap.remove(key, value);
            linkedHashMap.put(key, value);
        }
        return value;
    }

    public void set(int key, int value) {
         // write code here
        
        // 判断是插入操作还是变更操作
        int op = linkedHashMap.getOrDefault(key, -1);
        
        // 更改操作
        if (op != -1) {
            linkedHashMap.put(key, value);
        }
        
        // 插入操作
        else {
            int sz = linkedHashMap.size();
            // 判断当前容量是否已经达到了上限
            if (sz == capacity) {
                linkedHashMap.remove(linkedHashMap.keySet().toArray()[0]);
                linkedHashMap.put(key, value);
            }
            else {
                linkedHashMap.put(key, value);
            }
        }

    }
}

/**
 * Your Solution object will be instantiated and called as such:
 * Solution solution = new Solution(capacity);
 * int output = solution.get(key);
 * solution.set(key,value);
 */
全部评论
如果原本 linkedhashMap 就有 key,-1 这样的键值对呢
点赞 回复 分享
发布于 2022-04-20 13:22

相关推荐

10-17 12:16
同济大学 Java
7182oat:快快放弃了然后发给我,然后让我也泡他七天最后再拒掉,狠狠羞辱他一把😋
点赞 评论 收藏
分享
M_bao:换个排版吧哥们,看着费劲
点赞 评论 收藏
分享
评论
1
收藏
分享
牛客网
牛客企业服务