PHP数组大小比较与区间校验:如何高效验证数组元素是否落在指定区间之外?

高效验证php数组元素是否超出指定区间

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

PHP数组大小比较与区间校验:如何高效验证数组元素是否落在指定区间之外?

算法条件:

  1. 区间不相交: $arr1 中的任何元素都不能落在 $arr2 中任何一个区间内。
  2. 区间互斥: $arr2 中定义的所有区间必须互不重叠。
  3. 区间有效性: $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中文网其它相关文章!

https://www.php.cn/faq/1239121.html

发表回复

Your email address will not be published. Required fields are marked *