`

Leetcode - LRU Cache

 
阅读更多
[分析]
自己使用HashMap + LinkedList/ArrayList的都会超时,讨论区看到使用LinkedHashMap实现的版本https://leetcode.com/discuss/42891/probably-the-best-java-solution-extend-linkedhashmap,这个数据结构自己平常没用过,正好学习了~

import java.util.LinkedHashMap;
public class LRUCache {
    private int capacity;
    private Map<Integer,Integer> map;
    public LRUCache(int capacity) {
        map = new LinkedHashMap<Integer, Integer>(16, 0.75f, true) {
            protected boolean removeEldestEntry(Map.Entry eldest) {
                return size() > capacity;
            }
        };
    }
    
    public int get(int key) {
        return map.getOrDefault(key, -1);
    }
    
    public void set(int key, int value) {
        map.put(key, value);
    }
}
分享到:
评论

相关推荐

    js-leetcode题解之146-lru-cache.js

    javascript js_leetcode题解之146-lru-cache.js

    lrucacheleetcode-Leetcode-LRU-cache:146.LRU缓存

    Leetcode-LRU-cache LRU缓存 设计和实现最近最少使用 (LRU) 缓存的数据结构。 它应该支持以下操作:get 和 put。 get(key) - 如果键存在于缓存中,则获取键的值(将始终为正),否则返回 -1。 put(key, value) - ...

    python-leetcode题解之146-LRU-Cache

    python python_leetcode题解之146_LRU_Cache

    lrucacheleetcode-leetcode-LRU-Cache:我的leetcodeLRU缓存问题的解决方案

    lru缓存leetcode 问题描述 设计一个遵循最近最少使用 (LRU) 缓存约束的数据结构。 实现 LRUCache 类: LRUCache(int capacity)使用正大小容量初始化 LRU 缓存。 int get(int key)如果键存在则返回键的值,否则返回-1...

    leetcodelrucache-leetcode-LRUcache:leetcode-LRUcache

    当你在LeetCode上遇到“LRU Cache”这个题目时,通常会要求实现一个数据结构,它具有以下特性: 1. **添加和获取元素**:LRU Cache 允许你在O(1)的时间复杂度内添加或获取元素。这意味着无论缓存的大小如何,这些...

    lrucacheleetcode-leetcode-practices:leetcode-实践

    @lru_cache(None) 使用动态规划避免重复工作 2020 年 1 月 6 日 合并两个排序列表 / 可以使用递归实现 通过使用指针也可以具有 O(1) 复杂度 2020 年 1 月 7 日 类似做法 斐波那契数 爬楼梯 有效括号 快乐号/ 2020 年...

    javalruleetcode-LeetCode-Solutions:LeetCode-解决方案

    本项目 "javalruleetcode-LeetCode-Solutions" 针对 LeetCode 上的 Java 相关问题,提供了一套解决方案,特别是针对基于LRU Cache(最近最少使用)策略的问题。本文将深入探讨 LRUCache 的实现原理,并结合 LeetCode...

    lrucacheleetcode-leetcode-in-go:leetcode-in-go

    lru-cache-0146 动态规划 爬楼梯-0070 coin-change-0322 coin-change-ii-0518 组合和-iv-0377 解码方式-0091 盗家贼-0198 盗家贼-ii-0213 jump-game-0055 最长公共子序列1143 最长公共子串 最长递增子序列0300 最大...

    lrucacheleetcode-LeetCode-Tencent50:Leetcode中Tencent50的代码和注释

    lru cache leetcode LeetCode-Tencent50 Task0 最小栈 Task1 有效的括号 Task2 数组中的第K个最大元素 Task3 合并K个有序链表 Task4 买卖股票的最佳时机 II Task5 排序链表 Task6 子集 Task7 只出现一次的数字 Task8...

    算法面试通关40讲完整课件 57-58 LRU Cache

    例如,在LeetCode等在线编程平台上,"LRU Cache"是一个常被提及的面试题。 除此之外,LRU Cache策略与其它缓存淘汰策略如LFU(Least Frequently Used)等存在显著差异。与LRU基于时间最近性的原则不同,LFU依据数据...

    javalruleetcode-LRU_cache:LRU_cache

    LRU_cache (Leetcode 146) 设计和实现最近最少使用 (LRU) 缓存的数据结构。 它应该支持以下操作:get 和 set。 get(key) – 如果键存在于缓存中,则获取键的值(将始终为正),否则返回 -1。 set(key, value) – ...

    lrucacheleetcode-leetcode-algorithm:leetcode算法由python3和cpp求解

    在编程领域,LRU Cache经常被用作数据结构设计的问题,特别是在算法面试和LeetCode等在线编程挑战平台中。 这个名为"lrucacheleetcode-leetcode-algorithm"的压缩包文件显然包含了解决LeetCode算法问题的代码,主要...

    lrucacheleetcode-leetcode-1:leetcode-1

    lru cache leetcode Leetcode Solution 1. Two Sum 二重循环遍历 2. Add Two Numbers 链表求和,哨兵节点 3. Longest Substring Without Repeating Characters 最长没有重复字符的子序列 记录各字符最近一次出现的...

    lrucacheleetcode-LeetCode-go:力密码

    lru cache leetcode LeetCode-go leetcode中文网站 目录 序号 名字 中文名字 备注 0 binarySearch 二分查找法 1 两数之和 2 两数相加 3 longestSubstr 无重复最长字串 4 findMedianSortedArrays 寻找两个有序数组的...

    leetcode-leetcode:我的leetcode解决方案

    对应的代码文件为lru-cache.cpp About This Repo 所有代码均为原创,可随意转载、使用、修改,请标明出处。 代码不追求最短,但追求逻辑上清楚,易于重复。 不采用太偏门的方法,保证代码易读、易理解。 如果你有不...

    lrucacheleetcode-Leetcode-Practice-GHC19:开始作为GraceHopper2019的实践学习小组

    lru缓存leetcode Leetcode-练习-GHC19 最初是作为关于代码实践的 whatsapp 研究小组更新的存储库 - 用于 Grace Hopper ...Cache-3 次 力码 361 力码 463 二叉搜索树到排序数组。 截留雨水。 整数到罗

    lrucacheleetcode-lru_cache:lru_cache

    lru缓存leetcode LRU缓存 受启发的简单 LRU 缓存实现 发展 建造 ./gradlew build 测试 ./gradlew test 使用示例 LRUCache&lt; String , String &gt; cache = new LRUCache&lt;&gt; ( 2 /* capacity */ ); cache . put( " ...

    lrucacheleetcode-leetcode-cs:LeetCodeC#提交与xUnit.net单元测试

    lru缓存leetcode leetcode-cs 带有单元测试的 C# 提交。 强调 简单的 HashSet , IEnumerable.Count() string.Substring() , string.Concat() Array.Sort() , hat operator (^) HashSet Stack , IEnumerable....

    lrucacheleetcode-leetcode-lfu-cache:我的leetcodeLFU缓存问题的解决方案

    lru缓存leetcode 问题描述 设计和实现最不常用 (LFU) 缓存的数据结构。 实现 LFUCache 类: LFUCache(int capacity)用数据结构的容量初始化对象。 int get(int key)如果键存在于缓存中,则获取int get(int key)的值...

Global site tag (gtag.js) - Google Analytics