题目描述:
Given a list of 24-hour clock time points in “Hour:Minutes” format, find the minimum minutes difference between any two time points in the list.
Example 1:
1 2 3
| Input: ["23:59","00:00"] Output: 1
|
Note:
- The number of time points in the given list is at least 2 and won’t exceed 20000.
- The input time is legal and ranges from 00:00 to 23:59.
先进行排序,然后依次计算相邻时间的时间差,这个时间差有两个方向,选择较小的一个。最后要注意还要算最后一个时间与第一个时间的时间差。
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
| class Solution { public: int findMinDifference(vector<string>& timePoints) { if (timePoints.size() >= 1440) return 0; sort(timePoints.begin(), timePoints.end()); int minDiff = INT_MAX; for (int i = 1; i < timePoints.size(); i++) { minDiff = min(minDiff, calcDiff(timePoints[i - 1], timePoints[i])); } minDiff = min(minDiff, calcDiff(timePoints[0], timePoints.back())); return minDiff; } int calcDiff (string &a, string &b) { int aH = stoi(a.substr(0, 2)), bH = stoi(b.substr(0, 2)), aM = stoi(a.substr(3, 2)), bM = stoi(b.substr(3, 2)); int diff; if (bH == aH) { return bM - aM; } else { diff = (60 - aM) + bM + (bH - aH - 1) * 60; } return min(diff, 1440 - diff); } };
|