>  기사  >  백엔드 개발  >  求教,数组排序解决思路

求教,数组排序解决思路

WBOY
WBOY원래의
2016-06-13 09:59:14855검색

求教,数组排序
有一数组, 想要根b1和a进行二次排序,当b1不同时,按b1正序排列,当b1相同时,按a正序排列。要求效率要高。

PHP code
<!--Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->array(    [0] = array(        ['a'] = 323,        ['b'] = array(            ['b1'] = 1            )        )        [1] = array(        ['a'] = 234,        ['b'] = array(            ['b1'] = 1            )        )    [2] = array(        ['a'] = 135,        ['b'] = array(            ['b1'] = 2            )        ))


------解决方案--------------------
这意思?
PHP code
<?phpfunction cmp($a,$b){    return $a['b']['b1'] == $b['b']['b1']?($a['a'] - $b['a']):($a['b']['b1'] - $b['b']['b1']);}$array = array(0=>array('a'=>323,'b'=>array('b1'=>1)),               1=>array('a'=>324,'b'=>array('b1'=>1)),               2=>array('a'=>135,'b'=>array('b1'=>2)),);usort($array,'cmp');var_export($array);<br><font color="#e78608">------解决方案--------------------</font><br>
探讨
这意思?

PHP code
function cmp($a,$b){
return $a['b']['b1'] == $b['b']['b1']?($a['a'] - $b['a']):($a['b']['b1'] - $b['b']['b1']);
}

$array = array(0=>array('a'=>323,'b'=>array('b1'=>1)……
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.