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字符串
如果有什么问题或者更好的题解,欢迎在评论区斧正和评论,各自努力,你我最高处见
标签:00,Java,String,23,示例,1736,time,最晚,LeetCode 来源: https://www.cnblogs.com/bc-song/p/15055031.html