博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数组排序问题
阅读量:6261 次
发布时间:2019-06-22

本文共 2547 字,大约阅读时间需要 8 分钟。

1.usort():使用用户自定义的比较函数对数组进行排序。

   语法:usort(array,myfunction);

   返回值:如果成功则返回TRUE,如果失败则返回FALSE。

 $s=array('0'=>array('a'=>'jack','b'=>'Rose','c'=>'Mary'),'1'=>array('a'=>'blue','b'=>'green','c'=>'red'),'2'=>array('a'=>'orange','b'=>'apple','c'=>'pear'));

 usort($s,function($t,$k){

     if($t['b']==$k['b']) return 0;

     return ($t['b']>$k['b'])?1:-1;//此为按数组键值降序排列

});

 print_r($s);

输出结果为:

2.sort():对数值数组进行升序排序。

   语法:sort(array,sortingtype);

    sortingtype:可选。规定如何排列数组的元素/项目。可能的值:

  • 0 = SORT_REGULAR - 默认。把每一项按常规顺序排列(Standard ASCII,不改变类型)。
  • 1 = SORT_NUMERIC - 把每一项作为数字来处理。
  • 2 = SORT_STRING - 把每一项作为字符串来处理。
  • 3 = SORT_LOCALE_STRING - 把每一项作为字符串来处理,基于当前区域设置(可通过 进行更改)。
  • 4 = SORT_NATURAL - 把每一项作为字符串来处理,使用类似  的自然排序。
  • 5 = SORT_FLAG_CASE - 可以结合(按位或)SORT_STRING 或 SORT_NATURAL 对字符串进行排序,不区分大小写。

     $s = array(3,1,2);

     sort($s);

     print_r($s);

输出结果为:

3.resort():对数值数组进行降序排序。

   $s = array(3,1,2);

   sort($s);

   print_r($s);

输出结果为:

4.asort():对关联数组按照键值进行升序排序。

   语法:asort(array,sortingtype);

   $s = array("Peter"=>"39","Ben"=>"37","Joe"=>"43");

   asort($s);
   print_r($s);

输出结果为:

 

5.arsort():对关联数组按照键值进行降序排序。

   $s = array("Peter"=>"39","Ben"=>"37","Joe"=>"43");

   asort($s);
   print_r($s);

输出结果为:

6.ksort():对关联数组按照键名进行升序排序。

   $s = array("Peter"=>"39","Ben"=>"37","Joe"=>"43");

   ksort($s);
   print_r($s);

输出结果为:

7.krsort():对关联数组按照键名进行降序排序。

   $s = array("Peter"=>"39","Ben"=>"37","Joe"=>"43");

   krsort($s);
   print_r($s);

输出结果为:

8.uasort():使用用户自定义的比较函数对数组中的键值进行排序并保持索引关联。

   $s = array("Peter"=>"39","Ben"=>"37","Joe"=>"43");

   uasort($s,function($a,$b){
        if($a==$b) return 0;
        return ($a<$b)?1:-1;
   });
   print_r($s);

输出结果为:

9.uksort():使用用户自定义的比较函数对数组按键名进行排序并保持索引关联。

   $s = array("Peter"=>"39","Ben"=>"37","Joe"=>"43");

   uksort($s,function($a,$b){
        if($a==$b) return 0;
         return ($a<$b)?1:-1;
       });
   print_r($s);

输出结果为:

 

10.array_multisort():返回一个排序数组。您可以输入一个或多个数组。函数先对第一个数组进行排序,接着是其他数组,如果两个或多个值相同,它将对下一个数组进行排序。

注释:字符串键名将被保留,但是数字键名将被重新索引,从0开始,并以1递增。

         您可以在每个数组后设置排序顺序和排序类型参数。如果没有设置,每个数组参数会使用默认值。

   语法:array_multisort(arrray1,sorting order,sorting type,array2,array3......)

           sorting order:可选。规定排列顺序。可能的值:SORT_ASC - 默认。按升序排列 (A-Z)。SORT_DESC - 按降序排列 (Z-A)。

           sorting type:可选。规定排序类型。可能的值:SORT_REGULAR - 默认。把每一项按常规顺序排列(Standard ASCII,不改变类型)。SORT_NUMERIC - 把每一项作为数字来处理。SORT_STRING - 把每一项作为字符串来处理。SORT_LOCALE_STRING - 把每一项作为字符串来处理,基于当前区域设置(可通过 进行更改)。SORT_NATURAL - 把每一项作为字符串来处理,使用类似  的自然排序。SORT_FLAG_CASE - 可以结合(按位或)SORT_STRING 或 SORT_NATURAL 对字符串进行排序,不区分大小写。

11.shuffle():把数组中的元素按随机顺序重新排列。

     注释:该函数为数组中的元素分配新的键名,已存在的键名将被删除。

     $s = array("Peter"=>"39","Ben"=>"37","Joe"=>"43");

     shuffle($s);
     print_r($s);

输出结果为:

   

输出结果为:

    

 

转载于:https://www.cnblogs.com/apeandcat/p/6229546.html

你可能感兴趣的文章
python基础知识踩点
查看>>
3月5日云栖精选夜读 | 2019阿里云开年Hi购季新用户分会场全攻略!
查看>>
IJCAI阿里论文 | JUMP: 一种点击和停留时长的协同预估器
查看>>
腾讯十年投资记
查看>>
搭建直播平台需要从CDN“内部”入手
查看>>
python实现堆栈数据结构及其基本方法
查看>>
制造业瓶颈如何突破?“智变与突破——制造业人工智能产业峰会·南京”来献策...
查看>>
Linux shell 遍历
查看>>
MySQL ERROR 1372 (HY000): Password hash should be a 41-digit hexadecimal number
查看>>
如何设计一个高可用的运营系统
查看>>
SQL数据库学习之路(一)
查看>>
Prometheus监控实践:Kubernetes集群监控
查看>>
创建表格存储(Table Store)结果表
查看>>
网站301跳转
查看>>
Android 权限管理
查看>>
Django配置MySQL数据库及采坑记
查看>>
关于DialogFragment全屏方案
查看>>
WPF中查看PDF文件
查看>>
旷视科技 CSG 算法负责人姚聪:深度学习时代的文字检测与识别技术 | AI 研习社 103 期大讲堂...
查看>>
构建docker镜像
查看>>