下面是一个基于堆算法的用于查找排列的 PHP 函数。该函数在 JavaScript 中运行良好,但在 PHP 中失败。为什么 ?
function generate($n,$A) {
if ($n === 1) {
var_dump($A);
return $A;
} else {
for ($i = 0; $i < $n - 1; $i++) {
generate($n - 1, $A);
if ($n % 2 === 0) {
$t = $A[$i];
$A[$i] = $A[$n - 1];
$A[$n - 1] = $t;
}else {
$t = $A[0];
$A[0] = $A[$n - 1];
$A[$n - 1] = $t;
}
}
generate($n - 1, $A);
}
}
generate(3,array('a','b','c'));
函数的输出应该如下:
[ "a", "b", "c" ],
[ "b", "a", "c" ],
[ "c", "a", "b" ],
[ "a", "c", "b" ],
[ "b", "c", "a" ],
[ "c", "b", "a" ],
但我得到:
[ "a", "b", "c" ],
[ "b", "a", "c" ],
[ "c", "b", "a" ],
[ "b", "c", "a" ],
[ "a", "b", "c" ],
[ "b", "a" ,"c" ]