请你给一个停车场设计一个停车系统。停车场总共有三种不同大小的车位:大,中和小,每种尺寸分别有固定数目的车位。
请你实现 ParkingSystem 类:
ParkingSystem(int big, int medium, int small) 初始化 ParkingSystem类,三个参数分别对应每种停车位的数目。bool addCar(int carType) 检车是否有 carType 对应的停车位。 carType 有三种类型:大,中,小,分别用数字 1, 2 和 3 表示。一辆车只能停在 carType 对应尺寸的停车位中。如果没有空车位,请返回 false ,否则将该车停入车位并返回 true力扣公司的员工都使用员工卡来开办公室的门。每当一个员工使用一次他的员工卡,安保系统会记录下员工的名字和使用时间。如果一个员工在一小时时间内使用员工卡的次数大于等于三次,这个系统会自动发布一个 警告 。
给你字符串数组 keyName 和 keyTime ,期中 [keyName[i], keyTime[i]] 对应一个人的名字和他在 某一天 内使用员工卡的时间。
使用时间的格式是 24小时制 ,形如 “HH:MM” ,比方说 “23:51” 和 “09:49” 。
请你返回去重后的收到系统警告的员工名字,将它们按 字典序升序 排序后返回。
请注意 “10:00” - “11:00” 视为一个小时时间范围内,而 “23:51” - “00:10” 不被视为一小时内,因为系统记录的是某一天内的使用情况。
思路:使用map,将每个人使用时间(转换为分钟即可)放进去之后进行排序!!然后判断,这个时间每隔两个数之差有没有满足<=60,如果满足的话那么就将其加入res结果数组中即可,最后将res排序返回。
代码:
class Solution { public List<String> alertNames(String[] keyName, String[] keyTime) { //定义结果数组 List<String> res = new ArrayList<>(); //存放每个人的使用时间 Map<String, List<Integer>> map = new HashMap<>(); for(int i = 0; i < keyName.length; i++){ //如果不存在就往里放,有就不用继续放了,放time即可 if(!map.containsKey(keyName[i])){ map.put(keyName[i],new ArrayList<>()); } //计算使用时间 String[] times = keyTime[i].split(":"); int first = Integer.parseInt(times[0]); int second = Integer.parseInt(times[1]); map.get(keyName[i]).add(first * 60 + second); } //遍历之后每个list要进行排序,否则会漏掉情况 for(String key : map.keySet()){ Collections.sort(map.get(key)); int size = map.get(key).size(); //取出来判断 for(int i = 2; i < size; i++){ if(map.get(key).get(i) - map.get(key).get(i - 2) <= 60){ res.add(key); break; } } } //排序后返回 Collections.sort(res); return res; } }