3

我有以下数组,我需要从最高分到最低分进行排序。

Array
(
    [0] => Array
        (
            [team id] => 5
            [score] => 52
            [fouls] => 0
        )

    [1] => Array
        (
            [team id] => 4
            [score] => 47
            [fouls] => 0
        )

    [2] => Array
        (
            [team id] => 8
            [score] => 46
            [fouls] => 6
        )

    [3] => Array
        (
            [team id] => 1
            [score] => 46
            [fouls] => 5
        )

    [4] => Array
        (
            [team id] => 9
            [score] => 46
            [fouls] => 3
        )

)

上面的数组已经用这个函数排序了:

function sortByOrder($a, $b){
    $Return = $b['score'] - $a['score'];
    return $Return;
}

usort($Array, 'sortByOrder');

这似乎工作正常,因为得分最高的数组在列表中。

但是,有些球队得分相同,但犯了一些犯规。当一个分数等于另一个分数时,如何调整函数以将犯规也考虑在内?犯规最少的球队应该放在更高的位置。

期待创造性的解决方案!

提前致谢。

4

2 回答 2

7

你只需要更新你的功能sortByOrder()

基本上:

function sortByOrder($a, $b){
  if ($b['score'] == $a['score'])
    return $a['fouls'] - $b['fouls'];
  else
    return $b['score'] - $a['score'];
}
于 2012-05-16T08:56:49.383 回答
0

我想你正在使用usort将你的数组排序成一个顺序而不维护条目的原始键关联。

当您的主要排序相等时,您可以使用以下方法进一步优化排序函数以打破平局:

function sortByOrder($a, $b) {
    if ($a['score'] == $b['score']) {
        return ($a['fouls'] < $b['fouls']) ? -1 : 1;;
    }
    return ($a['score'] < $b['score']) ? -1 : 1;
}

注意 请注意,使用您的用户定义的排序方法,在这种情况下您需要返回的唯一两个值是 -1(a 小于 b)和 1(a 大于 b)。

于 2012-05-16T08:57:23.917 回答