概述
转载请注明来自souldak,微博:@evagle
接口就两个,get和set。
但是第一次写TLE,开始用的是单链表,单链表有个不好的地方是,容量满了之后,要删除最后一个元素会及其困难,必须从表头开始遍历。
为了不遍历,必须使用双向链表,然后记录链表结尾。
然后还有一个可以改进的地方是:get的时候,为了不从头开始扫描,用HashMap记录所有元素的引用。直接从Hashmap中取,O(1),然后再更新这个节点到链表头部,也是O(1).set 的时候,先从Hashmap中判断是否已经存在,存在的话修改值,然后移动到头部,如果不存在,新建节点,插入链表头部。也是O(1). 这样的话就不会超时了。
注意点: 如果移动的是最后一个元素的时候,要注意不要引用这个元素的next,它是空指针。
最后
以上就是飘逸百合为你收集整理的leetcode LRUCache的全部内容,希望文章能够帮你解决leetcode LRUCache所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复