牛牛总是睡过头,所以他定了很多闹钟,只有在闹钟响的时候他才会醒过来并且决定起不起床。从他起床算起他需要X分钟到达教室,上课时间为当天的A时B分,请问他最晚可以什么时间起床
输入描述:
每个输入包含一个测试用例。
每个测试用例的第一行包含一个正整数,表示闹钟的数量N(N<=100)。
接下来的N行每行包含两个整数,表示这个闹钟响起的时间为Hi(0<=A<24)时Mi(0<=B<60)分。
接下来的一行包含一个整数,表示从起床算起他需要X(0<=X<=100)分钟到达教室。
接下来的一行包含两个整数,表示上课时间为A(0<=A<24)时B(0<=B<60)分。
数据保证至少有一个闹钟可以让牛牛及时到达教室。
输出描述:
输出两个整数表示牛牛最晚起床时间。
输入例子1:
3
5 0
6 0
7 0
59
6 59
输出例子1:
6 0
这个题比较简单,
- 别忘了给闹钟排序。
- 找到第一个早于起床时间的值别忘break掉循环
也可以用二分查找吧。我写了顺序查找
clock_num = int(input())
clock_time =[]
for i in range(clock_num):
hour,minute = list(map(int,input().split()))
clock_time.append(hour*60+minute) # 时间是0-24点,直接换成分钟表示
clock_time = sorted(clock_time) # 求最晚时间,从小到大排个序
X = int(input())
time = list(map(int,input().split()))
Time = time[0]*60+time[1]
latest_time = Time - X # 真实的最晚起床时间
for i in range(clock_num-1,-1,-1):
if clock_time[i] <= latest_time: # 从大到小遍历闹钟时间,找到第一个早于真实起床时间的返回
late = clock_time[i]
break #!!!!非常重要!!!!
# 换算成 时+分格式
hour = int(late/60)
minute = late%60
print(str(hour)+' '+str(minute))