PHP的数字排序

男娘i 2022-05-11 23:12 406阅读 0赞

一 实例

  1. <?php
  2. $array=array(1,4,8,25,0,42,88,66);
  3. $array1=sort($array,SORT_STRING); //用sort()函数对$array数组进行升序排序,并返回新数组$array1
  4. for($i=0;$i<count($array);$i++){ //应用for循环语句输出数组元素
  5. echo $array[$i]." ";
  6. }
  7. ?>

二 运行结果

0 1 25 4 42 66 8 88

当将 SORT_STRING修改为 SORT_REGULAR ,排序顺序如下:

0 1 4 8 25 42 66 88

三 总结

SORT_STRING 排序方式的底层实现是 C 语言的 memcmp,也就是说,它对两个字符串从前往后,按照逐个字节比较,一旦字节有差异,就终止并比较出大小。

SORT_REGULAR 会智能判断需排序对象的类型,如果两个字符串都是“纯数字”形式的字符串,会以比较整个字符串所代表的十进制整数、浮点数大小的形式进行排序。如果两个字符串不是“纯数字“形式的,才会和 SORT_STRING 一样。

因此,如果需要以字符串 strcmp 方式逐个字节从前往后比较来进行排序,在调用 php 的 sort 类函数的时候请务必使用 SORT_STRING 这个 flag,否则如果两个字符串都是”纯数字“形式的,就会按照它们所代表的数字大小进行排序。

而且需要注意的是,如果两个值的类型不同,那么这样的比较是毫无意义的,也可能会产生意想不到的结果。

发表评论

表情:
评论列表 (有 0 条评论,406人围观)

还没有评论,来说两句吧...

相关阅读

    相关 PHP排序算法:快速排序

    快速排序是一种常用的排序算法,它基于分治法的思想。该算法通过选择一个基准元素,将数组划分为两个子数组,其中一个子数组的所有元素都小于基准元素,另一个子数组的所有元素都大于基准元

    相关 字符数字排序

    题目信息 输入一串字符串,包含数字、大小写字母和特殊字符。请将数字按照降序排列,字母按照升序排列。排列后,数字放在数字的位置,字母放在字母位置。 示例输入:3p0i1r

    相关 数字排序

    数字排序程序,相信很多人都会编写。 但是在单片机的操作界面上,现场输入数字、递增(递减)排序,好像还没有见过。 下面请看:   利用51单片机、LCD1602、4×4键

    相关 CCF 数字排序

    一.问题描述 给定n个整数,请统计出每个整数出现的次数,按出现次数从多到少的顺序输出。 输入格式   输入的第一行包含一个整数n,表示给定数字的个数。   第