你将获得多条日志,每条日志都有唯一的 id
和 timestamp
,timestamp
是形如 Year:Month:Day:Hour:Minute:Second
的字符串,2017:01:01:23:59:59
,所有值域都是零填充的十进制数。
实现 LogSystem
类:
LogSystem()
初始化LogSystem
对象void put(int id, string timestamp)
给定日志的id
和timestamp
,将这个日志存入你的存储系统中。int[] retrieve(string start, string end, string granularity)
返回在给定时间区间[start, end]
(包含两端)内的所有日志的id
。start
、end
和timestamp
的格式相同,granularity
表示考虑的时间粒度(例如,精确到Day
、Minute
等)。例如start = "2017:01:01:23:59:59"
、end = "2017:01:02:23:59:59"
且granularity = "Day"
意味着需要查找从 Jan. 1st 2017 到 Jan. 2nd 2017 范围内的日志,可以忽略日志的Hour
、Minute
和Second
。
示例:
输入: ["LogSystem", "put", "put", "put", "retrieve", "retrieve"] [[], [1, "2017:01:01:23:59:59"], [2, "2017:01:01:22:59:59"], [3, "2016:01:01:00:00:00"], ["2016:01:01:01:01:01", "2017:01:01:23:00:00", "Year"], ["2016:01:01:01:01:01", "2017:01:01:23:00:00", "Hour"]] 输出: [null, null, null, null, [3, 2, 1], [2, 1]] 解释: LogSystem logSystem = new LogSystem(); logSystem.put(1, "2017:01:01:23:59:59"); logSystem.put(2, "2017:01:01:22:59:59"); logSystem.put(3, "2016:01:01:00:00:00"); // 返回 [3,2,1],返回从 2016 年到 2017 年所有的日志。 logSystem.retrieve("2016:01:01:01:01:01", "2017:01:01:23:00:00", "Year"); // 返回 [2,1],返回从 Jan. 1, 2016 01:XX:XX 到 Jan. 1, 2017 23:XX:XX 之间的所有日志 // 不返回日志 3 因为记录时间 Jan. 1, 2016 00:00:00 超过范围的起始时间 logSystem.retrieve("2016:01:01:01:01:01", "2017:01:01:23:00:00", "Hour");
提示:
1 <= id <= 500
2000 <= Year <= 2017
1 <= Month <= 12
1 <= Day <= 31
0 <= Hour <= 23
0 <= Minute, Second <= 59
granularity
是这些值["Year", "Month", "Day", "Hour", "Minute", "Second"]
之一- 最多调用
500
次put
和retrieve