LeetCode 981. Time Based Key-Value Store
原题链接在这里:https://leetcode.com/problems/time-based-key-value-store/
题目:
Create a timebased key-value store class TimeMap, that supports two operations.
1. set(string key, string value, int timestamp)
- Stores the keyandvalue, along with the giventimestamp.
2. get(string key, int timestamp)
- Returns a value such that set(key, value, timestamp_prev)was called previously, withtimestamp_prev <= timestamp.
- If there are multiple such values, it returns the one with the largest timestamp_prev.
- If there are no values, it returns the empty string ("").
Example 1:
Input: inputs = ["TimeMap","set","get","get","set","get","get"], inputs = [[],["foo","bar",1],["foo",1],["foo",3],["foo","bar2",4],["foo",4],["foo",5]]
Output: [null,null,"bar","bar",null,"bar2","bar2"]
Explanation:
TimeMap kv;
kv.set("foo", "bar", 1); // store the key "foo" and value "bar" along with timestamp = 1
kv.get("foo", 1); // output "bar"
kv.get("foo", 3); // output "bar" since there is no value corresponding to foo at timestamp 3 and timestamp 2, then the only value is at timestamp 1 ie "bar"
kv.set("foo", "bar2", 4);
kv.get("foo", 4); // output "bar2"
kv.get("foo", 5); //output "bar2"
Example 2:
Input: inputs = ["TimeMap","set","set","get","get","get","get","get"], inputs = [[],["love","high",10],["love","low",20],["love",5],["love",10],["love",15],["love",20],["love",25]]
Output: [null,null,null,"","high","high","low","low"]
Note:
- All key/value strings are lowercase.
- All key/value strings have length in the range [1, 100]
- The timestampsfor allTimeMap.setoperations are strictly increasing.
- 1 <= timestamp <= 10^7
- TimeMap.setand- TimeMap.getfunctions will be called a total of- 120000times (combined) per test case.
题解:
For the same key, if timestamp is different, value could be different.
There could be cases <key, value1> with timestamp1, <key, value2> with timestamp2. Both values are stored. The second value is NOT overriding first value.
Have a HashMap<String, TreeMap<Integer, String>> hm to store keys. The value is TreeMap sorted based on timestamp.
set, update hm. get, first get the TreeMap based on key, then use floorKey to find the largest key <= timestamp.
Time Complexity: set, O(logn). get, O(logn). n = max(TreeMap size).
Space: O(m*n). m = hm.size().
AC Java:
 class TimeMap {
     HashMap<String, TreeMap<Integer, String>> hm;
     /** Initialize your data structure here. */
     public TimeMap() {
         hm = new HashMap<>();
     }
     public void set(String key, String value, int timestamp) {
         hm.putIfAbsent(key, new TreeMap<>());
         hm.get(key).put(timestamp, value);
     }
     public String get(String key, int timestamp) {
         if(!hm.containsKey(key)){
             return "";
         }
         TreeMap<Integer, String> item = hm.get(key);
         Integer time = item.floorKey(timestamp);
         return time == null ? "" : item.get(time);
     }
 }
 /**
  * Your TimeMap object will be instantiated and called as such:
  * TimeMap obj = new TimeMap();
  * obj.set(key,value,timestamp);
  * String param_2 = obj.get(key,timestamp);
  */
LeetCode 981. Time Based Key-Value Store的更多相关文章
- Leetcode 981. Time Based Key-Value Store(二分查找)
		题目来源:https://leetcode.com/problems/time-based-key-value-store/description/ 标记难度:Medium 提交次数:1/1 代码效率 ... 
- etcd -> Highly-avaliable key value store for shared configuration and service discovery
		The name "etcd" originated from two ideas, the unix "/etc" folder and "d&qu ... 
- 【LeetCode】981. Time Based Key-Value Store 解题报告(Python)
		作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 字典 日期 题目地址:https://leetcod ... 
- 【leetcode】981. Time Based Key-Value Store
		题目如下: Create a timebased key-value store class TimeMap, that supports two operations. 1. set(string ... 
- LC 981. Time Based Key-Value Store
		Create a timebased key-value store class TimeMap, that supports two operations. 1. set(string key, s ... 
- 【LeetCode】482. License Key Formatting 解题报告(Python)
		作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ... 
- LeetCode算法题-License Key Formatting(Java实现)
		这是悦乐书的第241次更新,第254篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第108题(顺位题号是482).您将获得一个表示为字符串S的许可证密钥,该字符串仅包含字 ... 
- 【leetcode】482. License Key Formatting
		problem 482. License Key Formatting solution1: 倒着处理,注意第一个字符为分隔符的情况要进行删除,注意字符的顺序是否正序. class Solution ... 
- LeetCode 981.基于时间的键值存储(C++)
		创建一个基于时间的键值存储类 TimeMap,它支持下面两个操作: 1. set(string key, string value, int timestamp) 存储键 key.值 value,以及 ... 
随机推荐
- SQL Server优化之SET STATISTICS开关(转载)
			一.准备工作 缓存对于某个查询的性能影响十分之大,所以优化之前要清空缓存. 清除Buffer Pool里面的所有缓存 DBCC DROPCLEANBUFFERS 清除Buffer Pool里的所有缓存 ... 
- [個人紀錄] windows form , usercontrol design 模式不見
			windows form 跟 usercontrol 都變成cs檔 無法點擊進入設計模式 <Compile Include="Form1.cs"/> <Compi ... 
- C# 使用SuperSocket
			一.需求场景 (1)使用SuperSocket进行网络通信 二.所需软件 (1)SocketTool 三.实现步骤 (1)使用Nuget管理器安装SuperSocket.Engine 该插件已经包 ... 
- Windows下载安装RabbitMQ教程
			原文链接:http://www.studyshare.cn/software/details/1171/0一.下载 1.下载Erlang 官网下载:去下载 百度网盘下载:去下载 提取码:m1q0 2 ... 
- a属性+DOM创建回流+动画运动+
			超链接a的属性 href分析: < a href = " " > 点击刷新页面,相当于向后台发送了一次请求 < a href = " # &quo ... 
- hello world之vivado程序解决方法
			体验米尔zynq系列Z-turn Board单板时,我开始用vivado.在安装vivad工程中出了一些问题,经过不懈的重新安装,终于成功了. 下面分享我用vivado设计hello world程序: ... 
- 【转载】 使用宝塔Linux面板功能查看服务器内存使用情况
			运维过阿里云服务器或者腾讯云服务器的运维人员都知道,针对占用内存比较高的应用或者服务等,我们需要时刻关注服务器的内存使用率,是否存在内存瓶颈等情况的出现.阿里云和腾讯云官方后台界面的监控数据页面也有相 ... 
- 使用nginx 做kbmmw REST 服务的负载均衡
			我们一般在云上部署REST服务.既想利用kbmmw 的方便性,又想保证系统的安全性,同时 想通过负载均衡保证服务器的健壮性.下面我们使用ubuntu+nginx 来实现以下kbmmw rest 服务器 ... 
- Ajax跨域问题及解决方案  asp.net core 系列之允许跨越访问(Enable Cross-Origin Requests:CORS)   c#中的Cache缓存技术   C#中的Cookie   C#串口扫描枪的简单实现   c#Socket服务器与客户端的开发(2)
			Ajax跨域问题及解决方案 目录 复现Ajax跨域问题 Ajax跨域介绍 Ajax跨域解决方案 一. 在服务端添加响应头Access-Control-Allow-Origin 二. 使用JSONP ... 
- LP线性规划初识
			认识LP 线性规划(Linear Programming) 特指目标函数和约束条件皆为线性的最优化问题. 目标函数: 多个变量形成的函数 约束条件: 由多个等式/不等式形成的约束条件 线性规划: 在线 ... 
