高效验证php数组元素是否超出指定区间
本文介绍一种PHP算法,用于高效验证一个包含数字的一维数组($arr1)的元素是否都位于另一个包含数字区间的二维数组($arr2)定义的区间之外。该算法需满足三个条件:区间不相交、区间互斥和区间有效性。

算法条件:
$arr1 中的任何元素都不能落在 $arr2 中任何一个区间内。$arr2 中定义的所有区间必须互不重叠。$arr2 中每个区间的起始值必须小于结束值。PHP代码实现:
立即学习“PHP免费学习笔记(深入)”;
<?php
$arr1 = [8, 17, 23, 22, 25, 30, 42];
$arr2 = [[12, 15], [24, 28], [17, 25], [29, 33]];
function compareArrays($arr1, $arr2) {
// 检查区间有效性
foreach ($arr2 as $interval) {
if ($interval[0] >= $interval[1]) {
return "Error: Invalid interval found in arr2.";
}
}
// 检查区间互斥性
for ($i = 0; $i < count($arr2); $i++) {
for ($j = $i + 1; $j < count($arr2); $j++) {
if (max($arr2[$i][0], $arr2[$j][0]) <= min($arr2[$i][1], $arr2[$j][1])) {
return "Error: Overlapping intervals found in arr2.";
}
}
}
// 检查区间不相交性
foreach ($arr1 as $num) {
foreach ($arr2 as $interval) {
if ($num >= $interval[0] && $num <= $interval[1]) {
return "Error: Element $num from arr1 falls within an interval in arr2.";
}
}
}
return "No errors found.";
}
echo compareArrays($arr1, $arr2); // 输出错误信息,因为区间重叠且元素落在区间内
$arr2_correct = [[12, 15], [16, 23], [29, 33]]; //修正后的$arr2
echo compareArrays($arr1, $arr2_correct); // 输出 "No errors found." (如果$arr1和$arr2_correct没有冲突)
?>这段代码首先验证 $arr2 中区间的有效性和互斥性,然后检查 $arr1 中的元素是否落在 $arr2 的任何区间内。任何违反条件的情况都会返回相应的错误信息。如果没有发现错误,则返回 "No errors found."。 请注意,这只是一个示例,实际应用中可能需要根据具体需求进行调整和优化,例如处理非数字数据或更复杂的区间定义。
以上就是PHP数组大小比较与区间校验:如何高效验证数组元素是否落在指定区间之外?的详细内容,更多请关注php中文网其它相关文章!
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号