| 替换隐藏数字得到的最晚时间给你一个字符串 time ,格式为 hh:mm(小时:分钟),其中某几位数字被隐藏(用 ? 表示)。
 有效的时间为 00:00 到 23:59 之间的所有时间,包括 00:00 和 23:59 。 替换 time 中隐藏的数字,返回你可以得到的最晚有效时间。 示例 1: 输入:time = “2?:?0”输出:“23:50”
 解释:以数字 ‘2’ 开头的最晚一小时是 23 ,以 ‘0’ 结尾的最晚一分钟是 50 。
 示例 2:
 输入:time = “0?:3?”输出:“09:39”
 示例 3:
 输入:time = “1?:22”输出:“19:22”
 提示: time 的格式为 hh:mm题目数据保证你可以由输入的字符串生成有效的时间
 class Solution {
public:
    string maximumTime(string time) {
        if (time[0] == '?') {
            time[0] = ('4' <= time[1] && time[1] <= '9') ? '1' : '2';
        }
        if (time[1] == '?') {
            time[1] = (time[0] == '2') ? '3' : '9';
        }
        if (time[3] == '?') {
            time[3] = '5';
        }
        if (time[4] == '?') {
            time[4] = '9';
        }
        return time;
    }
};
 作者:LeetCode-Solution链接:https://leetcode-cn.com/problems/latest-time-by-replacing-hidden-digits/solution/ti-huan-yin-cang-shu-zi-de-dao-de-zui-wa-0s7r/
 ------------------------------My ans--------------- class Solution {
public:
    string maximumTime(string time) {
        for (int i = 0; i < time.length(); ++i) {
            if (time[i] == '?') {
                switch(i) {
                    case 0 : 
                        if ('4' <= time[i + 1] && time[i + 1] <= '9') time[i] = '1';
                        else time[i] = '2';
                        break;
                    case 1 : 
                        if (time[i - 1] != '2') time[i] = '9';
                        else time[i] = '3';
                        break;
                    case 3 : 
                        time[i] = '5';
                        break;
                    case 4 : 
                        time[i] = '9';
                        break;
                }
            }
        }
        return time;
    }
};
 |