牛客题霸NC93-设计LRU缓存结构-题解

经典的LRU缓存数据结构设计题,用HashMap和自定义双端队列结构实现,时间复杂度o(1),空间复杂度o(n)
import java.util.*;

public class Solution {
    /**
     * lru design
     * @param operators int整型二维数组 the ops
     * @param k int整型 the k
     * @return int整型一维数组
     */
    class DNode{
        DNode next;
        DNode prev;
        int val;
        int key;
        public DNode(int val){
            this.val = val;
        }
        
        public DNode(int key, int val){
            this.key = key;
            this.val = val;
        }
    }
    
    public Solution(){
        head = new DNode(0);
        tail = new DNode(0);
        head.next = tail;
        tail.next = head;
        size = 0;
        map = new HashMap<>();
    }
    
    DNode head;
    DNode tail;
    int size;
    Map<Integer, DNode> map;
    int capacity;
    
    private void set(int key, int val){
        if (map.containsKey(key)){
            DNode node = map.get(key);
            node.val = val;
            delete(node);
            moveToFirst(node);
        }else{
            if(size == capacity){
                DNode last = tail.prev;
                delete(last);
                map.remove(last.key);
                size--;
            }
            DNode node = new DNode(key, val);
            map.put(key, node);
            size++;
            moveToFirst(node);
        }
    }
    
    private int get(int key){
        if (map.containsKey(key)){
            DNode node = map.get(key);
            delete(node);
            moveToFirst(node);
            return node.val;
        }else{
            return -1;
        }
    }
    
    private void delete(DNode node){
        DNode prev = node.prev;
        DNode next = node.next;
        prev.next = next;
        next.prev = prev;
    }
    
    private void moveToFirst(DNode node){
        DNode next = head.next;
        head.next = node;
        node.next = next;
        next.prev = node;
        node.prev = head;
    }
    
    public int[] LRU (int[][] operators, int k) {
        // write code here
        capacity = k;
        List<Integer> ans = new ArrayList<>();
        for (int[] operator : operators){
            if (operator[0] == 1){
                set(operator[1], operator[2]);
            }else{
                int temp = get(operator[1]);
                ans.add(temp);
            }
        }
        return ans.stream().mapToInt(Integer::intValue).toArray();
    }
}

#题解#
全部评论

相关推荐

牛客120493863号:你姐东南大学硕士在读,那就找导师或者师兄师姐打听下同门同方向前辈就业最好的是去向哪几家公司了呗(如果不想走考公选调的话),这个是最有参考性的。
点赞 评论 收藏
分享
威猛的小饼干正在背八股:挂到根本不想整理
点赞 评论 收藏
分享
评论
2
1
分享
牛客网
牛客企业服务