zoukankan      html  css  js  c++  java
  • leetcode 146. LRU Cache ----- java

    esign and implement a data structure for Least Recently Used (LRU) cache. It should support the following operations: get and set.

    get(key) - Get the value (will always be positive) of the key if the key exists in the cache, otherwise return -1.
    set(key, value) - Set or insert the value if the key is not already present. When the cache reached its capacity, it should invalidate the least recently used item before inserting a new item.

    第一次遇到的设计的题目

    其实就是简单实现LRU即Least Recently Used 近期最少使用算法。

    1、使用了HashMap和ArrayList

    public class LRUCache {
        
        int size,num;
        List<Integer> list ;
        Map<Integer,Integer> map;
    
        public LRUCache(int capacity) {
    
            size = capacity;
            num = 0;
            list = new ArrayList<Integer>();
            map = new HashMap<Integer,Integer>();
    
    
        }
    
        public int get(int key) {
            if( map.containsKey(key) ){
                list.remove((Integer)key);
                list.add(key);
                return map.get(key);
            }
            else
                return -1;
    
        }
    
        public void set(int key, int value) {
            
    
            
            if( map.containsKey(key) ){
                list.remove((Integer)key);
                map.put(key,value);
                list.add(key);
            }else{
                if( num == size ){
                    map.remove(list.get(0));    
                    list.remove((int)0);
                    map.put(key,value);
                    list.add(key);  
                }else{
                    map.put(key,value);
                    list.add(key);
                    num++;
                }
            }
            
            
            
    
    
        }
    }

    2、使用LinkedHashMap.

    public class LRUCache {

       int size,num; Map<Integer,Integer> map; public LRUCache(int capacity) { size = capacity; List list =new LinkedList(); map = new LinkedHashMap<Integer,Integer>(); } public int get(int key) { if( map.containsKey(key) ){ int value = map.get(key); map.remove(key); map.put(key,value); return value; } else return -1; } public void set(int key, int value) { if( map.containsKey(key) ){ map.remove(key); map.put(key,value); }else{ if( num == size ){ int firstKey = map.keySet().iterator().next(); map.remove(firstKey); map.put(key,value); }else{ map.put(key,value); num++; } } } }

    3、可以使用双向链表实现。

  • 相关阅读:
    merge into update
    buffer overflow
    在表中循环插入日期
    判断表是否存在 存储
    listagg( ) within group ( order by ) 与 wm_concat
    Oracle导入SQL脚本执行 scott 用户下的表删除了
    数据导入时注意点,修改登录密码不区分大小写
    分页
    创建触发器在表中播入数据时ID自动增长
    insert 另外一种用法
  • 原文地址:https://www.cnblogs.com/xiaoba1203/p/6069555.html
Copyright © 2011-2022 走看看