为什么array_uinterselect()在array1&array2、array1&array1和array2&array2之间比较元素? [英] Why does array_uintersect() compare elements between array1 & array2, array1 & array1, and array2 & array2?

查看:82
本文介绍了为什么array_uinterselect()在array1&array2、array1&array1和array2&array2之间比较元素?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

测试脚本

$i = 0;
array_uintersect(['foo', 'bar'], ['baz', 'qux'], function($a, $b) use (&$i) {
    print_r([$a, $b, $i++]);
});

实际结果

Array
(
    [0] => bar
    [1] => foo
    [2] => 0
)
Array
(
    [0] => qux
    [1] => baz
    [2] => 1
)
Array
(
    [0] => bar
    [1] => qux
    [2] => 2
)
Array
(
    [0] => bar
    [1] => foo
    [2] => 3
)

预期结果

Array
(
    [0] => foo
    [1] => baz
    [2] => 0
)
Array
(
    [0] => bar
    [1] => qux
    [2] => 1
)

换句话说,我希望传递给回调的是左数组的当前元素和右数组的当前元素。

此外,如果我要向array_uintersect传递额外的数组-向回调传递多一个参数(例如,$c),我预计也会应用相同的逻辑。

有人能解释一下这种行为吗?

推荐答案

array_uintersect docs中没有提到的是,在内部,PHP sorts all the arrays先从左到右。仅数组排序后,PHP才遍历它们(再次从左到右)以查找交叉点。

第三个参数(比较函数)传递给内部排序算法,而不是交集算法。因此,看到的调试输出是计算排序的排序算法。

zend_sort implementation一般uses a bisecting quick sort implementation。对于示例中大小相同的数组,PHP使用插入排序。对于大型数组,PHP使用3或5点枢轴,以便improve worst-case complexity

由于您没有从比较函数显式返回任何值,因此PHP默认返回NULL(0),并且由于PHP使用插入排序,因此当排序遍历所有组合时,您将看到O(n*n)行为。

这篇关于为什么array_uinterselect()在array1&array2、array1&array1和array2&array2之间比较元素?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
相关文章
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆