【刷题日记】网易——牛牛的闹钟

牛牛总是睡过头,所以他定了很多闹钟,只有在闹钟响的时候他才会醒过来并且决定起不起床。从他起床算起他需要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

这个题比较简单,

  1. 别忘了给闹钟排序。
  2. 找到第一个早于起床时间的值别忘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))
        
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值