题意理解
给你一个字符串 time ,格式为 hh:mm(小时:分钟),其中某几位数字被隐藏(用 ? 表示)。
有效的时间为 00:00 到 23:59 之间的所有时间,包括 00:00 和 23:59 。
替换 time 中隐藏的数字,返回你可以得到的最晚有效时间。
问题分析
难点在于怎么考虑全所有的时间数字组合。
其他
https://leetcode-cn.com/problems/latest-time-by-replacing-hidden-digits/
链接
class Solution {
public:
string maximumTime(string time) {
string max_time="";
for (int i = 0; i < time.size(); i ++) {
char a = time[i];
if (a != '?') {
max_time.push_back(a);
} else {
if (i == 0 && (time[1] < '4' || time[1] == '?')) {
max_time.push_back('2');
}
if (i == 0 && (time[1] >= '4' && time[1] != '?')) {
max_time.push_back('1');
}
if (i == 1 && (max_time[0] == '1' || max_time[0] == '0')) {
max_time.push_back('9');
}
if (i == 1 && max_time[0] == '2') {
max_time.push_back('3');
}
if (i == 3) {
max_time.push_back('5');
}
if (i == 4) {
max_time.push_back('9');
}
}
}
return max_time;
}
};