问题描述例如有一个数组,存储的是一些整点数据,无排序无规律,ex:$hours=[1,3,6,2,13,16,18,20];现在需要快速得出当前时间最接近的整点数,如果当前整点在数组内,则为当前整点,如果不在,则获取下一个最接近的整点数,依次类推。整点数应该大于等于当前整点,但是得判断跨天的情况,列如当前时间点是21点,那符合条件的应该是1。问题出现的环境背景及自己尝试过哪些方法因为是时间整点,所以是24进制,没法直接判断最临近的数,所以目前想到的办法是循环这个数组,依次拼接出各个时间戳(还得判断是否为跨天),然后当前时间戳做减法,取绝对值,然后按照这个差值进行排序,获取符合条件的数,总觉得效率不高,请问有更好的解法吗?
慕姐8265434
长风秋雁
相关分类