> 백엔드 개발 > PHP 튜토리얼 > 时间的判断问题

时间的判断问题

WBOY
풀어 주다: 2016-06-23 13:45:48
원래의
981명이 탐색했습니다.

A1  2014-10-1   10:00:00
A2  2014-10-2   14:00:00
B1  2014-10-4   13:00:00
B2  2014-10-5   15:00:00

A1为开始时间,A2为结束时间,B1为开始时间,B2为结束时间
现在有时间 C1-C2

如何判断C1-C2,如果在A1-A2或者B1-B2里面或者有交叉,出现弹框提示。


回复讨论(解决方案)

转换成时间戳 然后比较大小

观察一个事实

$ar = array(  'A1' => '2014-10-1 10:00:00',  'A2' => '2014-10-2 14:00:00',  'B1' => '2014-10-4 13:00:00',  'B2' => '2014-10-5 15:00:00',);$ar['C1'] = '2014-10-3 13:00:00';$ar['C2'] = '2014-10-5 13:00:00';asort($ar);print_r($ar);
로그인 후 복사
로그인 후 복사
Array(    [A1] => 2014-10-1 10:00:00    [A2] => 2014-10-2 14:00:00    [C1] => 2014-10-3 13:00:00    [B1] => 2014-10-4 13:00:00    [C2] => 2014-10-5 13:00:00    [B2] => 2014-10-5 15:00:00)
로그인 후 복사
로그인 후 복사
根据键名就可准确的判断出来了吧?

观察一个事实

$ar = array(  'A1' => '2014-10-1 10:00:00',  'A2' => '2014-10-2 14:00:00',  'B1' => '2014-10-4 13:00:00',  'B2' => '2014-10-5 15:00:00',);$ar['C1'] = '2014-10-3 13:00:00';$ar['C2'] = '2014-10-5 13:00:00';asort($ar);print_r($ar);
로그인 후 복사
로그인 후 복사
Array(    [A1] => 2014-10-1 10:00:00    [A2] => 2014-10-2 14:00:00    [C1] => 2014-10-3 13:00:00    [B1] => 2014-10-4 13:00:00    [C2] => 2014-10-5 13:00:00    [B2] => 2014-10-5 15:00:00)
로그인 후 복사
로그인 후 복사
根据键名就可准确的判断出来了吧?



这是举例,实际数据是一堆的数组

无论有多少数据,算法都是不变的
只要依次检查键名,同组的“开始”和“结束”不相邻就是有交叉或嵌套

不写具体代码的原因是:你的情况远比示例复杂,写了你也套不上去。关键在于理解

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿