题目链接
英文链接:https://leetcode.com/problems/all-oone-data-structure/
中文链接:https://leetcode-cn.com/problems/all-oone-data-structure/
题目详述
实现一个数据结构支持以下操作:
- Inc(key) - 插入一个新的值为 1 的 key。或者使一个存在的 key 增加一,保证 key 不为空字符串。
- Dec(key) - 如果这个 key 的值是 1,那么把他从数据结构中移除掉。否者使一个存在的 key 值减一。如果这个 key 不存在,这个函数不做任何事情。key 保证不为空字符串。
- GetMaxKey() - 返回 key 中值最大的任意一个。如果没有元素存在,返回一个空字符串
""
。 - GetMinKey() - 返回 key 中值最小的任意一个。如果没有元素存在,返回一个空字符串
""
。
挑战:以 O(1) 的时间复杂度实现所有操作。
题目详解
类似于 LeetCode146-LRU缓存机制,运用 HashMap + 实现双向链表。
1 | public class LeetCode_00432 { |