[0635] 设计日志存储系统
- GitHub
- http://leetcode.xuezhisd.top/post/ea3403f1.html
- https://leetcode.com/problems/design-log-storage-system
- https://leetcode-cn.com/problems/design-log-storage-system
题目描述
你将获得多条日志,每条日志都有唯一的 id 和 timestamp,timestamp 是形如 Year:Month:Day:Hour:Minute:Second
的字符串,例如 2017:01:01:23:59:59
,所有值域都是零填充的十进制数。
设计一个日志存储系统实现如下功能:
void Put(int id, string timestamp)
:给定日志的 id 和 timestamp,将这个日志存入你的存储系统中。
int[] Retrieve(String start, String end, String granularity)
:返回在给定时间区间内的所有日志的 id。start 、 end 和 timestamp 的格式相同,granularity 表示考虑的时间级。比如,start = "2017:01:01:23:59:59", end = "2017:01:02:23:59:59", granularity = "Day" 代表区间 2017 年 1 月 1 日到 2017 年 1 月 2 日。
样例 1 :
put(1, "2017:01:01:23:59:59"); put(2, "2017:01:01:22:59:59"); put(3, "2016:01:01:00:00:00"); retrieve("2016:01:01:01:01:01","2017:01:01:23:00:00","Year"); // 返回值 [1,2,3],返回从 2016 年到 2017 年所有的日志。 retrieve("2016:01:01:01:01:01","2017:01:01:23:00:00","Hour"); // 返回值 [1,2], 返回从 2016:01:01:01 到 2017:01:01:23 区间内的日志,日志 3 不在区间内。
注释 :
- Put 和 Retrieve 的指令总数不超过 300。
- 年份的区间是 [2000,2017],小时的区间是 [00,23]。
- Retrieve 的输出顺序不作要求。
Related Topics
题目解析
- [请一句话描述题目…]
不确定性
方法一:[算法名称]
分析
思路
注意
知识点
复杂度
代码
1 | // |
方法二:[算法名称]
分析
思路
注意
知识点
复杂度
代码
1 | // |