PHP排序问题,arsort vs asort + array_reverse

时间:2012-07-23 19:15:25

标签: php sorting

我最近正在研究其中一个项目的euler问题集,并遇到了这个奇怪的问题。我已经使用第一个解决方案正确解决了问题,但我不知道为什么其他版本没有按预期工作。

以下是有效的代码:

asort($card_count, SORT_NUMERIC);
$card_count = array_reverse($card_count, true);

这里的代码不是:

arsort($card_count, SORT_NUMERIC);

这是我改变的唯一一条线,它对最终结果产生了巨大的影响。有什么想法吗?

1 个答案:

答案 0 :(得分:4)

问题出现在数组中排序相等的值。拿阵列:

$arr = array(
    'a' => 1,
    'b' => 1,
    'c' => 1,
    'd' => 1
);

在此阵列上调用asort($arr, SORT_NUMERIC)反转数组。因此,代码行:

asort($arr, SORT_NUMERIC);
$arr = array_reverse($arr, true);

会将数组放回原始订单

因此,添加一个更高的值,更改数组:

$arr = array(
    'a' => 1,
    'b' => 1,
    'c' => 2,
    'd' => 1
);

asort($arr, SORT_NUMERIC);
$arr = array_reverse($arr, true);

将会发生:

Array
(
    [c] => 2
    [a] => 1
    [b] => 1
    [d] => 1
)

,而

arsort($arr, SORT_NUMERIC);

将会发生:

Array
(
    [c] => 2
    [d] => 1
    [b] => 1
    [a] => 1
)

希望这能为这个问题提供一些启示......