我有以下数组,我需要从最高分到最低分数。
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');
这似乎工作正常,因为得分最高的数组会上升。
然而,有些球队得分相同但犯了一些犯规。如果分数等于另一个分数,我该如何调整功能以将犯规考虑在内?犯规次数最少的球队应该更高。
期待创意解决方案!
提前致谢。
答案 0 :(得分:7)
您只需更新功能sortByOrder()
。
基本上:
function sortByOrder($a, $b){
if ($b['score'] == $a['score'])
return $a['fouls'] - $b['fouls'];
else
return $b['score'] - $a['score'];
}
答案 1 :(得分: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;
}
NB请注意您的用户定义排序方法,在这种情况下您需要返回的唯一两个值是-1(a小于b)和1(a大于b)。