LeetCode——1736. 替换隐藏数字得到的最晚时间(Java)

题干描述

题干:
给你一个字符串 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"

题解思路

返回最大的时间,只要考虑好几种特殊情况去处理即可,简单的字符串问题

正确代码

class Solution {
    public String maximumTime(String time) {
        char[] arrTime = time.toCharArray();
        if (arrTime[0] == '?') {
            arrTime[0] = ('4' <= arrTime[1] && arrTime[1] <= '9') ? '1' : '2';
        }
        if (arrTime[1] == '?') {
            arrTime[1] = (arrTime[0] == '2') ? '3' : '9';
        }
        if (arrTime[3] == '?') {
            arrTime[3] = '5';
        }
        if (arrTime[4] == '?') {
            arrTime[4] = '9';
        }
        return new String(arrTime);
    }
}

总结

在 new String() 的时候,发现可以放进去一个数组,自动给你处理成String字符串

如果有什么问题或者更好的题解,欢迎在评论区斧正和评论,各自努力,你我最高处见
posted @ 2021-07-24 13:50  21岁还不是架构师  阅读(56)  评论(0编辑  收藏  举报