forked from neetcode-gh/leetcode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path0981-time-based-key-value-store.kt
47 lines (42 loc) · 1.49 KB
/
0981-time-based-key-value-store.kt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
class TimeMap {
private data class TimeStampValuePair(
val timestamp: Int,
val value: String
)
private val keyMap = mutableMapOf<String, MutableList<TimeStampValuePair>>()
fun set(key: String, value: String, timestamp: Int) {
keyMap.getOrPut(key, ::mutableListOf).add(TimeStampValuePair(timestamp, value))
}
fun get(key: String, timestamp: Int): String {
if (key !in keyMap.keys) return ""
val searchList = keyMap.getValue(key)
if (searchList.isEmpty()) return ""
return binarySearch(
list = searchList,
targetTimeStamp = timestamp
)
}
private fun binarySearch(
list: List<TimeStampValuePair>,
targetTimeStamp: Int
): String {
if (list.first().timestamp > targetTimeStamp) return ""
if (list.last().timestamp < targetTimeStamp) return list.last().value
var startIndex = 0
var endIndex = list.lastIndex
var midIndex: Int
var result = ""
while (startIndex <= endIndex) {
midIndex = startIndex + (endIndex - startIndex) / 2
when {
list[midIndex].timestamp <= targetTimeStamp -> {
if (list[midIndex].timestamp == targetTimeStamp) return list[midIndex].value
result = list[midIndex].value
startIndex = midIndex + 1
}
else -> endIndex = midIndex - 1
}
}
return result
}
}