php之 校验多个时间段是否重复

参考网址 https://www.kancloud.cn/xiaobaoxuetp/mywork/3069416

https://segmentfault.com/a/1190000020487996

PHP判断多个时间段是否存在跨天或重复叠加的场景

复制代码
/**
 * PHP计算两个时间段是否有交集(边界重叠不算)
 *
 * @param string $beginTime1 开始时间1
 * @param string $endTime1 结束时间1
 * @param string $beginTime2 开始时间2
 * @param string $endTime2 结束时间2
 * @return bool
*/
function is_time_cross($beginTime1 = '', $endTime1 = '', $beginTime2 = '', $endTime2 = '') {
  $status = $beginTime2 - $beginTime1;
  if ($status > 0) {
    $status2 = $beginTime2 - $endTime1;
    if ($status2 >= 0) {
      return false;
    } else {
      return true;
    }
  } else {
    $status2 = $endTime2 - $beginTime1;
    if ($status2 > 0) {
      return true;
    } else {
      return false;
    }
  }
}
$list = array(
    array('start_s'=>'10:00', 'end_s'=>'12:30'),
    array('start_s'=>'11:00', 'end_s'=>'12:30'),
    array('start_s'=>'14:00', 'end_s'=>'12:30'),
    array('start_s'=>'16:00', 'end_s'=>'12:30'),
);
$array = array();
foreach ($list as $k => $v) {
    // 时间转换成秒
    $start = explode(':', $v['start_s']);
    $end = explode(':', $v['end_s']);
    $start_time = $start[0]*3600+$start[1]*60;
    $end_time = $end[0]*3600+$end[1]*60;
    // 更新进新列表
    $array[] = array(
        'start_s'=>$start_time, 
        'end_s'=>$end_time, 
    );
    // 先判断有没有跨天
    if ($v['start_s'] > $v['end_s']) {
        $str = '存在跨天时间段:';
        $str .= '开始时间:'.$v['start_s'];
        $str .= ' 结束时间:'.$v['end_s'];
        die($str);
    }
}
// 判断天数重叠
foreach ($array as $k => $v) {
    foreach ($array as $kk => $vv) {
        if ($kk != $k) {
            // 存在跨天时间段
            if (is_time_cross($v['start_s'], $v['end_s'], $vv['start_s'], $vv['end_s'])) {
                $str = '存在重叠时间段:';
                $str .= '开始时间:'.date('H:i', $v['start_s']);
                $str .= ' 结束时间:'.date('H:i', $v['end_s']);
                $str .= ' 《 对应 》 开始时间:'.date('H:i', $vv['start_s']);
                $str .= ' 结束时间:'.date('H:i', $vv['end_s']);
                die($str);
            }
        }
    }
}
相关推荐
CYRUS_STUDIO1 小时前
一文搞懂 Frida Stalker:对抗 OLLVM 的算法还原利器
android·逆向·llvm
zcychong1 小时前
ArrayMap、SparseArray和HashMap有什么区别?该如何选择?
android·面试
CYRUS_STUDIO1 小时前
Frida Stalker Trace 实战:指令级跟踪与寄存器变化监控全解析
android·逆向
ace望世界6 小时前
android的Parcelable
android
顾林海6 小时前
Android编译插桩之AspectJ:让代码像特工一样悄悄干活
android·面试·性能优化
BingoGo7 小时前
PHP 如何利用 Opcache 来实现保护源码
后端·php
叽哥7 小时前
Flutter Riverpod上手指南
android·flutter·ios
循环不息优化不止7 小时前
安卓开发设计模式全解析
android
诺诺Okami7 小时前
Android Framework-WMS-层级结构树
android
alexhilton18 小时前
面向开发者的系统设计:像建筑师一样思考
android·kotlin·android jetpack