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

设计LRU缓存结构

http://www.nowcoder.com/practice/e3769a5f49894d49b871c09cadd13a61

定义一个LinkedHashMap来存取当前缓存里的key-value,遍历数组,如果第一位为1,且之后一位的key在map中没有,就把它加入到map当中,当key-value数量大于最大值k时移除第一个位置的key-value;
如果已经存在,将存在的key-value移除,添加当前key-value;如果第一位为2,为get操作,get找到了key就将其值加入定义的列表中,反之将-1加入列表中,之后将当前key-value移到最后进行下一步。数组遍历完,将
list里的值全部赋给结果数组返回
import java.util.*;


public class Solution {
    /**
     * lru design
     * @param operators int整型二维数组 the ops
     * @param k int整型 the k
     * @return int整型一维数组
     */
    public int[] LRU (int[][] operators, int k) {
        // write code here
         LinkedHashMap<Integer,Integer> map=new LinkedHashMap<>();
         List<Integer> list=new ArrayList<>();
         for(int[] op:operators){
             if(op[0]==1){
                 if(!map.containsKey(op[1])){
                     if(map.size()==k)
                         map.remove(map.keySet().iterator().next());
                     map.put(op[1],op[2]);
                 }else{
                     map.remove(op[1]);
                     map.put(op[1],op[2]);
                     
                 }
             }else if(op[0]==2){
                  if(map.containsKey(op[1])){
                      int val=map.get(op[1]);
                      list.add(val);
                      map.remove(op[1]);
                      map.put(op[1],val);
                  }
                  else{
                      list.add(-1);
                  }
             }
         }
        int[] res=new int[list.size()];
        for(int i=0;i<list.size();i++){
            res[i]=list.get(i);
        }
        return res;
    }
}


全部评论

相关推荐

Java抽象带篮子:难蚌,点进图片上面就是我的大头😆
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-29 12:19
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务