LRU 力扣 146 https://leetcode.cn/problems/lru-cache/


一道经典题目,用双向链表去做能够满足O1的复杂度

核心代码如下

class LRUCache {
   MyLinkedList myLinkedList;
   int size;
   int capacity;
   HashMap<Integer, MyNode> map;
   public LRUCache(int capacity) {


       myLinkedList=new MyLinkedList();
       this.capacity=capacity;
       size=0;
       map=new HashMap<>();
  }

   public int get(int key) {

       if (!map.containsKey(key)){
           return -1;
      }
   //   拿出来 放到顶部

       MyNode current = map.get(key);

       myLinkedList.deleteAndAddFirst(current);

       return current.val;
  }

   public void put(int key, int value) {

       if (map.containsKey(key)){
       //   老人了

           MyNode current = map.get(key);
           current.val=value;
           myLinkedList.deleteAndAddFirst(current);
           map.put(key,current);
      }else {

           if (size<capacity){
           //   直接放进来就行
               MyNode temp = new MyNode(key, value);
               myLinkedList.add(temp);
               map.put(key,temp);
               size++;
          }else {
           //   踢人了

               MyNode myNode = myLinkedList.removeLast();
               map.remove(myNode.key);

           //   再放进
               MyNode temp = new MyNode(key, value);
               myLinkedList.add(temp);
               map.put(key,temp);
               

          }






      }




  }
}
class MyLinkedList{
   MyNode head;
   MyNode tail;

   public MyLinkedList() {
       head=new MyNode(-1,-1);
       tail=new MyNode(-1,-1);
       head.next=tail;
       tail.pre=head;
  }

   /**
    * 把之前的放到新的位置
    * @param current
    */
   public void deleteAndAddFirst(MyNode current){

       //去除之前的位置
       MyNode next = current.next;
       MyNode pre = current.pre;

       pre.next=next;
       next.pre=pre;
       add(current);

  }

   public void add(MyNode current){

       MyNode old = head.next;
       current.next=old;
       head.next=current;
       old.pre=current;
       current.pre=head;


  }
   public MyNode  removeLast(){

       MyNode last = tail.pre;
       MyNode pre= last.pre;

       pre.next=tail;
       tail.pre=pre;
       return last;
  }
}

class MyNode{

   Integer key;
   Integer val;
   MyNode next;
   MyNode pre;

   public MyNode(Integer key, Integer val) {
       this.key = key;
       this.val = val;
  }
}

题解

posted @   故里oc  阅读(39)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
点击右上角即可分享
微信分享提示