我有一个函数,它检查两个数组并返回两个数组中的公共最小值。当两个数组具有相同数量的元素时,IT返回正确的答案。但是另一个更大它不会返回正确的那个。如何克服这个?
<?php
$A = array(0);
$B= array(1,0);
$n = sizeof($A);
$m = sizeof($B);
sort($A);
sort($B);
$i = 0;
for ($k = 0; $k < $n; $k++) {
if ($i < $m - 1 AND $B[$i] < $A[$k])
$i += 1;
if ($A[$k] == $B[$i])
echo $A[$k];
}
echo "end";
?>
由于
答案 0 :(得分:5)
更简单的方法是获取数组交集的最小值:
$array = array (5,6,7,8,9);
$array2 = array (9,7,5,3,4,1);
$min = min(array_intersect($array, $array2));
echo $min; // 5
答案 1 :(得分:0)
利用PHP函数array_intersect()提取两个数组中的常用值,然后使用min()
获取最小值像这样:
<?php
$arrayOne = [1, 3, 5, 6, 7];
$arrayTwo = [0, 9, 2, 3, 4, 5];
echo min(array_intersect($arrayOne, $arrayTwo)); // 3
答案 2 :(得分:0)
我会使用array_intersect。它将为您提供一个数组,其中只有您正在查看的数组中存在的值,然后您可以在数组中找到最低值
$A = array(0,5,4,3,2,1,4);
$B = array(0,1,3,4);
$C = array_intersect($A, $B);
$low = $C[0];
for($i = 0; $i < count($C); $i++) {
if($C[$i] < $low)
$low = $C[$i];
}
echo "Lowest shared number is $low";