Why does array_uintersect() compare elements between array1 amp;amp; array2, array1 amp;amp; array1, and array2 amp;amp; array2?(为什么array_uinterselect()在array1amp;amp;array2、array1amp;amp;array1和array2amp;amp;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&;amp;array2、array1&;amp;array1和array2&;amp;array2之间比较元素?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:为什么array_uinterselect()在array1&;amp;array2、array1&;amp;array1和array2&;amp;array2之间比较元素?
基础教程推荐
- 如何在 PHP 中的请求之间持久化对象 2022-01-01
- 在 PHP 中强制下载文件 - 在 Joomla 框架内 2022-01-01
- 超薄框架REST服务两次获得输出 2022-01-01
- 在 Woocommerce 中根据运输方式和付款方式添加费用 2021-01-01
- mysqli_insert_id 是否有可能在高流量应用程序中返回 2021-01-01
- WooCommerce 中选定产品类别的自定义产品价格后缀 2021-01-01
- XAMPP 服务器不加载 CSS 文件 2022-01-01
- Libpuzzle 索引数百万张图片? 2022-01-01
- 在多维数组中查找最大值 2021-01-01
- 通过 PHP SoapClient 请求发送原始 XML 2021-01-01