ホームページ >バックエンド開発 >PHPチュートリアル >複数のデータ範囲セットが重複しているかどうかを効果的に判断するにはどうすればよいでしょうか?
php
5000~7000
$a = array( array(5000, 7000), array(2000, 6000), array(8000, 9000), array(4000, 8500), array(5000, 7000),);$r = array();foreach($a as $v) { $r[] = $v[0]; $r[] = $v[1];}$r = array_unique($r);sort($r);$a = array();for($i=0; $i<count($r)-1; $i++) $a[] = array($r[$i], $r[$i+1]);;print_r($a);Array
<?php$array1 = array("a" => "green", "b" => "brown", "c" => "blue", "red");$array2 = array("a" => "green", "b" => "yellow", "blue", "red");$result_array = array_intersect_assoc($array1, $array2);print_r($result_array);?>
<?php$array1 = array("a" => "green", "b" => "brown", "c" => "blue", "red");$array2 = array("a" => "green", "b" => "yellow", "blue", "red");$result_array = array_intersect_assoc($array1, $array2);print_r($result_array);?>
この二次元配列は判定できません、
そしてこれが必要な場合、交差範囲内にありません。
array(
array(2000, 3000),
array(3000, 4000),
いくつかの変更を加えませんか?
元の配列に重複がある場合、重複を除いて生成された配列は元の配列より大きくなければなりません
求出具体范围按版主的程序
唉,单纯求true,false不就更简单了:
把任意两项的最小值跟另一项最大值比较就是了,一旦有交集->break循环,如果直到循环结束,就是无交集
你不会变通一下吗?
如果原始数组有重复,那么生成的无重复数组就一定比原始数组大
谢谢版主。
通过重新排序,重新生成新的无重复数组,
如果这个无重复数组元素个数发生变化,代表原始数组是有交集的,对吗?
像以下这两种情况似乎无法正确判断flag
$a = array(
array(5000, 7000),
array(6000, 8200),
array(8000, 9000)
);
$a = array(
array(5000, 5500),
array(6000, 6500),
array(8000, 8500)
);
还有没有更有效的方法呢。
只需要判别是否包含,可以写成函数
还是沿袭开始的思路
$a = array( array(5000, 7000), array(2000, 6000), array(8000, 9000), array(4000, 8500), array(5000, 7000),);var_dump(foo($a)); //bool(false)$a = array( array(5000, 7000), array(6000, 8200), array(8000, 9000));var_dump(foo($a)); //bool(false)$a = array( array(5000, 5500), array(6000, 6500), array(8000, 8500));var_dump(foo($a)); //bool(true)function foo($a) { $r = array_unique(call_user_func_array('array_merge', $a)); sort($r); foreach($a as $v) { if(array_search($v[0], $r) != array_search($v[1], $r) - 1) return false; } return true;}
只需要判别是否包含,可以写成函数
还是沿袭开始的思路
$a = array( array(5000, 7000), array(2000, 6000), array(8000, 9000), array(4000, 8500), array(5000, 7000),);var_dump(foo($a)); //bool(false)$a = array( array(5000, 7000), array(6000, 8200), array(8000, 9000));var_dump(foo($a)); //bool(false)$a = array( array(5000, 5500), array(6000, 6500), array(8000, 8500));var_dump(foo($a)); //bool(true)function foo($a) { $r = array_unique(call_user_func_array('array_merge', $a)); sort($r); foreach($a as $v) { if(array_search($v[0], $r) != array_search($v[1], $r) - 1) return false; } return true;}