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 の時間があります
A1-A2 に交差点がある場合、C1-C2 を判断する方法または 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)
データの量に関係なく、アルゴリズムは変わりません
キー名が順番にチェックされている限り、「開始」と「終了」が一致していれば、同じグループの「」は隣接していません。交差があります。または入れ子になっています
特定のコードを書かない理由は、あなたの状況は例よりもはるかに複雑であり、たとえあなたがそれを書きます。重要なのは理解することです