Easy
You are given two strings current
and correct
representing two 24-hour times.
24-hour times are formatted as "HH:MM"
, where HH
is between 00
and 23
, and MM
is between 00
and 59
. The earliest 24-hour time is 00:00
, and the latest is 23:59
.
In one operation you can increase the time current
by 1
, 5
, 15
, or 60
minutes. You can perform this operation any number of times.
Return the minimum number of operations needed to convert current
to correct
.
Example 1:
Input: current = “02:30”, correct = “04:35”
Output: 3
Explanation:
We can convert current to correct in 3 operations as follows:
Add 60 minutes to current. current becomes “03:30”.
Add 60 minutes to current. current becomes “04:30”.
Add 5 minutes to current. current becomes “04:35”.
It can be proven that it is not possible to convert current to correct in fewer than 3 operations.
Example 2:
Input: current = “11:00”, correct = “11:01”
Output: 1
Explanation: We only have to add one minute to current, so the minimum number of operations needed is 1.
Constraints:
current
and correct
are in the format "HH:MM"
current <= correct
class Solution {
private val duration = intArrayOf(60, 15, 5, 1)
private var c = 0
fun convertTime(current: String, correct: String): Int {
val dmin = correct.substring(3).toInt() - current.substring(3).toInt()
val dhour = correct.substring(0, 2).toInt() - current.substring(0, 2).toInt()
val min = dhour * 60 + dmin
dfs(0, min)
return c
}
private fun dfs(i: Int, amount: Int) {
if (i == 4) {
return
}
if (amount == 0) {
return
}
if (amount - duration[i] >= 0) {
c++
dfs(i, amount - duration[i])
} else {
dfs(i + 1, amount)
}
}
}