题解 | #设计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;
}
} 

