繁体   English   中英

基于多个值对多维数组进行排序

[英]Sort multidimensional array based on multiple values

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

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');

这似乎工作正常,因为得分最高的数组上升。

但是,有些球队得分相同但犯了一些犯规。 如果分数等于另一个分数,我该如何调整功能以将犯规考虑在内? 犯规次数最少的球队应该更高。

期待创意解决方案!

提前致谢。

您只需更新函数sortByOrder()

基本上:

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

我想你正在使用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)。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM