题目
受新冠疫情影响,当前大家的活动都必须注意保持充分的社交距离,国家实验室的使用也同样受到了严格的限制。假设规定任何一个时间点上,实验室内最多只能有 1 个人,且每个人都必须提前申请实验室的使用,只有申请被批准后才能进入。现给定一批第二天的实验室使用申请,你需要写个程序自动审批,使得能够被批准的申请数量最大化。
输入格式: 输入第一行首先给出一个正整数 N(≤2×10 3 ),为申请总量。随后 N 行,每行按以下格式给出申请信息:
hh:mm:ss hh:mm:ss 其中 hh:mm:ss 表示一天内的时间点“小时:分钟:秒钟”,最早从 00:00:00 开始,最晚到 23:59:59 结束。第一个时间点为进入实验室的时间,第二个是离开时间。题目保证离开时间在进入时间之后。
注意所有时间都在一天之内。时间按 24 小时显示。
输出格式: 在一行中输出能够被批准的最大申请数量。
输入样例: 7 18:00:01 23:07:01 04:09:59 11:30:08 11:35:50 13:00:00 23:45:00 23:55:50 13:00:00 17:11:22 06:30:50 11:42:01 17:30:00 23:50:00 结尾无空行 输出样例: 5 结尾无空行 样例解释: 除了最后两个申请,其它都可以被批准。
解题思路
N = int(input()) # N = 7 def zhuanhua(input:str)->int: h,m,s = map(int,input.split(":")) res = s+m*60+h*60*60 return res inputList = [] for _ in range(N): start, end = map(zhuanhua, input().split()) # start, end = map(zhuanhua, "18:00:01 23:07:01".split()) inputList.append((start, end)) inputList.sort(key= lambda x:(-x[1],x[0])) start = 0 maxEndTime = zhuanhua("23:59:59") res = 0 # print(inputList) for x,y in inputList: if y<=maxEndTime: maxEndTime = x res += 1 print(res)