Rumah >pembangunan bahagian belakang >tutorial php >PHP中usort()的使用方法

PHP中usort()的使用方法

墨辰丷
墨辰丷asal
2018-05-15 18:03:403237semak imbas


本篇文章主要介绍PHP中usort()的使用方法,感兴趣的朋友参考下,希望对大家有所帮助。

函数为对数组进行自己自定义排序,排序规则由 $cmp_function 定义。返回值为ture 或者false。

现在先对简单的一个函数进行分析:

<?php
function re($a,$b){
           return ($a<$b)?1:-1;
          }5 $x=array(1,3,2,5,9);
      usort($x, &#39;re&#39;)    
      print_r($x);
?>


打印结果为:

Array(
    [0] => 9
    [1] => 5
    [2] => 3
    [3] => 2
    [4] => 1<br>)

实现了数组的倒序排列。分析如下:

  usort两两提取数组中的数值,并按顺序输入自定义函数中,自定义函数根据内容返回1或者-1;usort根据返回值为1或者-1,得到传入的数值1“大于”或者“小于”数值2,然后对数值进行从小到大的排序。即:返回值为1,说明数值1“大于”数值2,然后排序:数值2—>数值1;返回值为-1,说明数值1“小于”数值2,然后排序:数值1->数值2。

  上面自定义函数中,$a74bea8fdfad27ee97c7e445ff0bfc0b7$a来排序;如果错误返回-1,说明说明$a"小于"$b,则按照顺序$a->$b来排序。

  下面进行一个较为复杂的排序:对一个数组先奇后偶,然后再进行从大到小排序。

function Compare($str1, $str2) { 
    if (($str1 % 2 == 0) && ($str2 %2 == 0)) { 
        if ($str1 > $str2) 
            return - 1; 
        else 
            return 1; 
    } 
    if ($str1 % 2 == 0) 
        return 1;
    if ($str2 % 2 == 0)
        return -1;
    return ($str2 > $str1) ? 1 : - 1;
}
$scores = array (22,57,55,12,87,56,54,11);
usort ( $scores, &#39;Compare&#39; );
print_r ( $scores );

实现步骤为:

1》判断输入的两个值是否都为偶数,都为偶数,进行从大到小排序;

2》如果不都为偶数,则至少一个为奇数,先判断$str1是否为偶数,如果为偶数,即:if($str1%2==0)成立,则返回1,意味着$str1“大于”$str2,则usort函数进行排序为“小的”$str2->“大的”$str1(偶数);

3》如果$str1为奇数,上面不返回任何值,接着判断$str2是否为偶数,如果为偶数,则返回-1,意味着$str1“小于”$str2,则usort函数进行排序为“小的”$str1(奇数)->“大的”$str2(偶数);

4》如果两个值都为奇数,则上面不返回任何值,接着对$str1和$str2进行从大到小排序;

输出结果为:

Array(
    [0] => 87
    [1] => 57
    [2] => 55
    [3] => 11
    [4] => 56
    [5] => 54
    [6] => 22
    [7] => 12
)

相关推荐:

如何运用PHP函数usort()实现自定义排序_PHP教程

PHP_I love U之(1)php衣食父母:使用usort()函数为二维数组排序

PHP中的usort() 函数是非稳定排序怎么办?

Atas ialah kandungan terperinci PHP中usort()的使用方法. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn