Maison  >  Article  >  développement back-end  >  求教,数组排序解决思路

求教,数组排序解决思路

WBOY
WBOYoriginal
2016-06-13 13:44:52790parcourir

求教,数组排序
有一数组, 想要根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
<?php 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)),
               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)……
Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn