php对数组排序,介绍了和php,有关的知识、技巧、经验,和一些php源码等。

对数组排序

  1. usort() 函数使用用户自定义的函数对数组排序。
  2. */
  3. function cmp($a, $b) //用户自定义回调函数
  4. {
  5. if($a==$b) //如果两个参数相等
  6. {
  7. return 0; //返回0
  8. }
  9. return($a>$b)?-1:1; //如果第1个参数大于第2个返回1,否则-1
  10. }
  11. $a=array(3,2,5,6,1); //定义一个数组
  12. usort ($a,"cmp"); //使用自定义函数对数组排序
  13. foreach($a as $key=>$value) //循环输出排序后的键值对
  14. {
  15. echo "$key:$valuen";
  16. }
  17. /*
  18. 注释:如果两个元素比较结果相同,则它们在排序后的数组中的顺序未经定义。到 php 4.0.6 之前,用户自定义函数将保留这些元素的原有顺序。但是由于在 4.1.0 中引进了新的排序算法,结果将不是这样了,因为对此没有一个有效的解决方案。
  19. */
  20. //对数组键名排序 uksort(array,sorttype)
  21. function cmp($a, $b) //用户自定义回调函数
  22. {
  23. if($a==$b) //如果两个参数相等
  24. {
  25. return 0; //返回0
  26. }
  27. return($a>$b)?-1:1; //如果第1个参数大于第2个返回1,否则-1
  28. }
  29. $a=array(4=>"four",3 =>"three",20 =>"twenty",10=>"ten"); //定义一个数组
  30. uksort ($a,"cmp"); //使用自定义函数对数组键名排序
  31. foreach($a as $key=>$value) //循环输出排序后的键值对
  32. {
  33. echo "$key:$valuen";
  34. }/*
  35. uksort() 函数使用用户自定义的比较函数按照键名对数组排序,并保持索引关系。
  36. 如果成功则返回 true,否则返回 false。
  37. 如果要排序的数组需要用一种不寻常的标准进行排序,那么应该使用此函数。
  38. 自定义函数应接受两个参数,该参数将被数组中的一对键名填充。比较函数在第一个参数小于,等于,或大于第二个参数时必须分别返回一个小于零,等于零,或大于零的整数。
  39. */
  40. /*
  41. sort() 函数按升序对给定数组的值排序。
  42. 注释:本函数为数组中的单元赋予新的键名。原有的键名将被删除。
  43. 如果成功则返回 true,否则返回 false。
  44. */
  45. $fruits=array("lemon","orange","banana","apple"); //定义一个数组
  46. sort($fruits); //对数组进行排序
  47. foreach($fruits as $key=>$val) //循环输出数组排序后的键值对
  48. {
  49. echo "$key=$valn"; //输出键值对
  50. }

您可能感兴趣的文章:
PHP二维数组排序的函数
php二维数组排序(实例)
php数组排序的几个函数(附实例)
PHP数组排序方法总结(收藏)
php 二维数组排序的两个例子
php 数组排序实例分享(多种排序方式)
php数组排序之krsort与asort函数应用举例
php 数组排序(升序、降序及相关问题)
php 数组排序的例子(不用内置函数)
php 简单数组排序的方法
php多维数组排序的例子
php二维数组排序的两种方法
php多维数组排序

php对数组排序代码的更多相关文章

  1. php 数组排序代码

    php对数组排序代码.   <?phpclass='pingjiaF' frameborder='0' src='http://www.jbxue.com' scrolling='no'> ...

  2. 数组排序代码,冒泡排序&快速排序&选择排序

    冒泡排序: for(var i=0;i<arr.length-1;i++){ for(var j=0;j<arr.length-1-i;j++){ if(arr[j]>arr[j+1 ...

  3. 第二章 jQuery数组和字符串

    章节内容: 1.利用数组在列表中显示名字 (1)利用数组显示名字列表--join()方法 (2)从数组中获取名字并追加到有序列表--each()方法 (3)利用HTML元素创建数组和计算数组长度--g ...

  4. Objective-C之NSArray(数组)默认排序与自定义排序

    在讲OC中数组的排序之前我先上一段代码,它是简单数组排序的一种方法(也就是元素是字符串或者数据的数组,因为后面要讲元素为类的数组排序) 代码1: NSArray *sortArr4 = [sortAr ...

  5. Runtime 、 Block

    1 使用Block方式,对学生对象进行排序. 1.1 问题 在iOS4.0+ 和Mac OS X 10.6+ 中添加了Block概念,以对C语言进行扩展.在Block中可以定义参数列表.返回类型,还可 ...

  6. hdu_1031_结构体排序

    题目很好理解,将列求和,取前k大的 我的代码思路:对列求和,后取出前k大的id加入结果数组,对比后面和第k大相同的评分id也加入到结果数组,最后对结果数组排序 代码: #include<cstd ...

  7. Java开发笔记(六十)匿名内部类的优势

    前面依次介绍了简单接口和扩展接口,给出的范例都是自定义的接口代码,其实Java系统本身就自带了若干行为接口,为了更好地理解系统接口的详细用法,接下来还是从一个基础的例子出发,抽丝剥茧地逐步说明接口的几 ...

  8. Java基础00-集合进阶26

    1. Collection Collection常用方法详解 1.1 集合知识回顾 1.2 集合类体系结构 集合存储数据的方式有单列和双列 Collection中还有List(可以存储可重复的数据)和 ...

  9. java数组排序(插入排序、冒泡排序、选择排序)与递归 代码示例

    import java.util.Scanner; public class OrderBy { public static void main(String[] args) { // Scanner ...

随机推荐

  1. CEP简介

    CEP即Complex Event Processing缩写,翻译过来就是复杂事件处理(复合事件可能更加准确).   1.为什么我们需要CEP?CEP是具有实时分析以及快速响应等等功能.下面让我们通过 ...

  2. Balloon Comes!

    Problem Description The contest starts now! How excited it is to see balloons floating around. You, ...

  3. UIWebView获得内容的高 高度自适应 宽度自适应

    UIWebView获得内容的高-作出自适应高的UIWebView- (void)webViewDidFinishLoad:(UIWebView *)webView { NSString *height ...

  4. 数据结构【一】:简单队列simple queue

    简单的FIFO队列实现,非线程安全! 1.queue.h : abstract data type queue #ifndef CUR_QUEUE_H #define CUR_QUEUE_H #inc ...

  5. MySQL(26):事务的隔离级别出现问题之 幻读

    1. 幻读 幻读(Phantom Read)又称为虚读,是指在一个事务内两次查询中数据条数不一致,幻读和不重复读有些类型,同样是在两次查询过程中,不同的是,幻读是由于其他事务做了插入记录的操作,导致记 ...

  6. 【Shell脚本学习13】Shell数组:shell数组的定义、数组长度

    Shell在编程方面比Windows批处理强大很多,无论是在循环.运算. bash支持一维数组(不支持多维数组),并且没有限定数组的大小.类似与C语言,数组元素的下标由0开始编号.获取数组中的元素要利 ...

  7. 《算法导论》习题解答 Chapter 22.1-6(求universal sink 通用汇点)

    思路:设置两个游标i指向行,j指向列,如果arr[i][j]==1,则i=max{i+1,j},j++:如果arr[i][j]==0,则j=max{i+1,j+1}. 伪代码: has_univers ...

  8. VsFTP+本地文件认证+SSl实现虚拟用户配置

    1.实验环境: [root@node21 ~]# cat /etc/centos-release CentOS release 6.8 (Final) [root@node21 ~]# uname - ...

  9. page59-一种能够累加数据的ADT(可视化版本) [可用于数据挖掘可视化工具]

    public class VisualAccumulator VisualAccumulator() 创建一个累加器 void addDataValue(double val) 添加一个新的数据值 d ...

  10. Storm累计求和中使用各种分组Grouping

    Shuffle Grouping: 随机分组, 随机派发stream里面的tuple, 保证bolt中的每个任务接收到的tuple数目相同.(它能实现较好的负载均衡) Fields Grouping: ...