首页技术php数组排序函数?php高级程序员

php数组排序函数?php高级程序员

编程之家2026-05-28891次浏览

大家好,今天给各位分享php数组排序函数的一些知识,其中也会对php高级程序员进行解释,文章篇幅可能偏长,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在就马上开始吧!

php数组排序函数?php高级程序员

PHP处理数组常用的几个函数

一、数组操作的基本函数

数组的键名和值

array_values($arr);获得数组的值

array_keys($arr);获得数组的键名

array_flip($arr);数组中的值与键名互换(如果有重复前面的会被后面的覆盖)

in_array("apple",$arr);在数组中检索apple

php数组排序函数?php高级程序员

array_search("apple",$arr);在数组中检索apple,如果存在返回键名

array_key_exists("apple",$arr);检索给定的键名是否存在数组中

isset($arr[apple]):检索给定的键名是否存在数组中

数组的内部指针

current($arr);返回数组中的当前单元

pos($arr);返回数组中的当前单元

php数组排序函数?php高级程序员

key($arr);返回数组中当前单元的键名

prev($arr);将数组中的内部指针倒回一位

next($arr);将数组中的内部指针向前移动一位

end($arr);将数组中的内部指针指向最后一个单元

reset($arr;将数组中的内部指针指向第一个单元

each($arr);将返回数组当前元素的一个键名/值的构造数组,并使数组指针向前移动一位

list($key,$value)=each($arr);获得数组当前元素的键名和值

数组和变量之间的转换

extract($arr);用于把数组中的元素转换成变量导入到当前文件中,键名当作变量名,值作为变量值

注:(第二个参数很重要,可以看手册使用)使用方法 echo$a;

compact(var1,var2,var3);用给定的变量名创建一个数组

二、数组的分段和填充

数组的分段

array_slice($arr,0,3);可以将数组中的一段取出,此函数忽略键名

array_splice($arr,0,3,array("black","maroon"));可以将数组中的一段取出,与上个函数不同在于返回的序列从原数组中删除

分割多个数组

array_chunk($arr,3,TRUE);可以将一个数组分割成多个,TRUE为保留原数组的键名

数组的填充

array_pad($arr,5,'x');将一个数组填补到制定长度

三、数组与栈

array_push($arr,"apple","pear");将一个或多个元素压入数组栈的末尾(入栈),返回入栈元素的个数

array_pop($arr);将数组栈的最后一个元素弹出(出栈)

四、数组与列队

array_shift($arr);数组中的第一个元素移出并作为结果返回(数组长度减1,其他元素向前移动一位,数字键名改为从零技术,文字键名不变)

array_unshift($arr,"a",array(1,2));在数组的开头插入一个或多个元素

五、回调函数

array_walk($arr,'function','words');使用用户函数对数组中的每个成员进行处理(第三个参数传递给回调函数function)

array_mpa("function",$arr1,$arr2);可以处理多个数组(当使用两个或更多数组时,他们的长度应该相同)

array_filter($arr,"function");使用回调函数过滤数组中的每个元素,如果回调函数为TRUE,数组的当前元素会被包含在返回的结果数组中,数组的键名保留不变

array_reduce($arr,"function","*");转化为单值函数(*为数组的第一个值)

六、数组的排序

通过元素值对数组排序

sort($arr);由小到大的顺序排序(第二个参数为按什么方式排序)忽略键名的数组排序

rsort($arr);由大到小的顺序排序(第二个参数为按什么方式排序)忽略键名的数组排序

usort($arr,"function");使用用户自定义的比较函数对数组中的值进行排序(function中有两个参数,0表示相等,正数表示第一个大于第二个,负数表示第一个小于第二个)忽略键名的数组排序

asort($arr);由小到大的顺序排序(第二个参数为按什么方式排序)保留键名的数组排序

arsort($arr);由大到小的顺序排序(第二个参数为按什么方式排序)保留键名的数组排序

uasort($arr,"function");使用用户自定义的比较函数对数组中的值进行排序(function中有两个参数,0表示相等,正数表示第一个大于第二个,负数表示第一个小于第二个)保留键名的数组排序

通过键名对数组排序

ksort($arr);按照键名正序排序

krsort($arr);按照键名逆序排序

uksort($arr,"function");使用用户自定义的比较函数对数组中的键名进行排序(function中有两个参数,0表示相等,正数表示第一个大于第二个,负数表示第一个小于第二个)

自然排序法排序

natsort($arr);自然排序(忽略键名)

natcasesort($arr);自然排序(忽略大小写,忽略键名)

七、数组的计算

数组元素的求和

array_sum($arr);对数组内部的所有元素做求和运算

数组的合并

array_merge($arr1,$arr2);合并两个或多个数组(相同的字符串键名,后面的覆盖前面的,相同的数字键名,后面的不会做覆盖操作,而是附加到后面)

“+”$arr1+$arr2;对于相同的键名只保留后一个

array_merge_recursive($arr1,$arr2);递归合并操作,如果数组中有相同的字符串键名,这些值将被合并到一个数组中去。如果一个值本身是一个数组,将按照相应的键名把它合并为另一个数组。当数组具有相同的数组键名时,后一个值将不会覆盖原来的值,而是附加到后面

数组的差集

array_diff($arr1,$arr2);返回差集结果数组

array_diff_assoc($arr1,$arr2,$arr3);返回差集结果数组,键名也做比较

数组的交集

array_intersect($arr1,$arr2);返回交集结果数组

array_intersect_assoc($arr1,$arr2);返回交集结果数组,键名也做比较

八、其他的数组函数

range(0,12);创建一个包含指定范围单元的数组

array_unique($arr);移除数组中重复的值,新的数组中会保留原始的键名

array_reverse($arr,TRUE);返回一个单元顺序与原数组相反的数组,如果第二个参数为TRUE保留原来的键名

//srand((float)microtime()*10000000);随机种子触发器

array_rand($arr,2);从数组中随机取出一个或多个元素

shuffle($arr);将数组的顺序打乱

求课吧有很多关于PHP编程方面的教程

php几种排序算法实例详解

四种排序算法的PHP实现:

1)插入排序(InsertionSort)的基本思想是:

每次将一个待排序的记录,按其关键字大小插入到前面已经排好序的子文件中的适当位置,直到全部记录插入完成为止。

2)选择排序(SelectionSort)的基本思想是:

每一趟从待排序的记录中选出关键字最小的记录,顺序放在已排好序的子文件的最后,直到全部记录排序完毕。

3)冒泡排序的基本思想是:

两两比较待排序记录的关键字,发现两个记录的次序相反时即进行交换,直到没有反序的记录为止。

4)快速排序实质上和冒泡排序一样,都是属于交换排序的一种应用。所以基本思想和上面的冒泡排序是一样的。

1.sort.php文件如下:

<?php

classSort{

private$arr=array();

private$sort='insert';

private$marker='_sort';

private$debug=TRUE;

/**

*构造函数

*

*@paramarray例如:

$config=array(

'arr'=>array(22,3,41,18),//需要排序的数组值

'sort'=>'insert',//可能值:insert,select,bubble,quick

'debug'=>TRUE//可能值:TRUE,FALSE

)

*/

publicfunctionconstruct($config=array()){

if(count($config)>0){

$this->_init($config);

}

}

/**

*获取排序结果

*/

publicfunctiondisplay(){

return$this->arr;

}

/**

*初始化

*

*@paramarray

*@returnbool

*/

privatefunction_init($config=array()){

//参数判断

if(!is_array($config)ORcount($config)==0){

if($this->debug===TRUE){

$this->_log("sort_init_param_invaild");

}

returnFALSE;

}

//初始化成员变量

foreach($configas$key=>$val){

if(isset($this->$key)){

$this->$key=$val;

}

}

//调用相应的成员方法完成排序

$method=$this->sort.$this->marker;

if(!method_exists($this,$method)){

if($this->debug===TRUE){

$this->_log("sort_method_invaild");

}

returnFALSE;

}

if(FALSE===($this->arr=$this->$method($this->arr)))

returnFALSE;

returnTRUE;

}

/**

*插入排序

*

*@paramarray

*@returnbool

*/

privatefunctioninsert_sort($arr){

//参数判断

if(!is_array($arr)ORcount($arr)==0){

if($this->debug===TRUE){

$this->_log("sort_array(insert)_invaild");

}

returnFALSE;

}

//具体实现

$count=count($arr);

for($i=1;$i<$count;$i++){

$tmp=$arr[$i];

for($j=$i-1;$j>=0;$j--){

if($arr[$j]>$tmp){

$arr[$j+1]=$arr[$j];

$arr[$j]=$tmp;

}

}

}

return$arr;

}

/**

*选择排序

*

*@paramarray

*@returnbool

*/

privatefunctionselect_sort($arr){

//参数判断

if(!is_array($arr)ORcount($arr)==0){

if($this->debug===TRUE){

$this->_log("sort_array(select)_invaild");

}

returnFALSE;

}

//具体实现

$count=count($arr);

for($i=0;$i<$count-1;$i++){

$min=$i;

for($j=$i+1;$j<$count;$j++){

if($arr[$min]>$arr[$j])$min=$j;

}

if($min!=$i){

$tmp=$arr[$min];

$arr[$min]=$arr[$i];

$arr[$i]=$tmp;

}

}

return$arr;

}

/**

*冒泡排序

*

*@paramarray

*@returnbool

*/

privatefunctionbubble_sort($arr){

//参数判断

if(!is_array($arr)ORcount($arr)==0){

if($this->debug===TRUE){

$this->_log("sort_array(bubble)_invaild");

}

returnFALSE;

}

//具体实现

$count=count($arr);

for($i=0;$i<$count;$i++){

for($j=$count-1;$j>$i;$j--){

if($arr[$j]<$arr[$j-1]){

$tmp=$arr[$j];

$arr[$j]=$arr[$j-1];

$arr[$j-1]=$tmp;

}

}

}

return$arr;

}

/**

*快速排序

*@bywww.5wx.org

*@paramarray

*@returnbool

*/

privatefunctionquick_sort($arr){

//具体实现

if(count($arr)<=1)return$arr;

$key=$arr[0];

$left_arr=array();

$right_arr=array();

for($i=1;$i<count($arr);$i++){

if($arr[$i]<=$key)

$left_arr[]=$arr[$i];

else

$right_arr[]=$arr[$i];

}

$left_arr=$this->quick_sort($left_arr);

$right_arr=$this->quick_sort($right_arr);

returnarray_merge($left_arr,array($key),$right_arr);

}

/**

*日志记录

*/

privatefunction_log($msg){

$msg='date['.date('Y-m-dH:i:s').']'.$msg.'

';

return@file_put_contents('sort_err.log',$msg,FILE_APPEND);

}

}

/*Endoffilesort.php*/

/*Locationhtdocs/sort.php*/

2.sort_demo.php文件如下:

<?php

require_once('sort.php');

$config=array(

'arr'=>array(23,22,41,18,20,12,200303,2200,1192),

//需要排序的数组值

'sort'=>'select',

//可能值:insert,select,bubble,quick

'debug'=>TRUE

//可能值:TRUE,FALSE

);

$sort=newSort($config);

//var_dump($config['arr']);

var_dump($sort->display());

/*Endofphp*/

php array怎么使用

PHP Array简介

array函数允许您对数组进行操作。

PHP支持单维和多维的数组。同时提供了用数据库查询结果来构造数组的函数。

安装

array函数是 PHP核心的组成部分。无需安装即可使用这些函数。

PHP Array函数

PHP:指示支持该函数的最早的 PHP版本。

函数

描述

PHP

array()创建数组。 3

array_change_key_case()返回其键均为大写或小写的数组。 4

array_chunk()把一个数组分割为新的数组块。 4

array_combine()通过合并两个数组来创建一个新数组。 5

array_count_values()用于统计数组中所有值出现的次数。 4

array_diff()返回两个数组的差集数组。 4

array_diff_assoc()比较键名和键值,并返回两个数组的差集数组。 4

array_diff_key()比较键名,并返回两个数组的差集数组。 5

array_diff_uassoc()通过用户提供的回调函数做索引检查来计算数组的差集。 5

array_diff_ukey()用回调函数对键名比较计算数组的差集。 5

array_fill()用给定的值填充数组。 4

array_filter()用回调函数过滤数组中的元素。 4

array_flip()交换数组中的键和值。 4

array_intersect()计算数组的交集。 4

array_intersect_assoc()比较键名和键值,并返回两个数组的交集数组。 4

array_intersect_key()使用键名比较计算数组的交集。 5

array_intersect_uassoc()带索引检查计算数组的交集,用回调函数比较索引。 5

array_intersect_ukey()用回调函数比较键名来计算数组的交集。 5

array_key_exists()检查给定的键名或索引是否存在于数组中。 4

array_keys()返回数组中所有的键名。 4

array_map()将回调函数作用到给定数组的单元上。 4

array_merge()把一个或多个数组合并为一个数组。 4

array_merge_recursive()递归地合并一个或多个数组。 4

array_multisort()对多个数组或多维数组进行排序。 4

array_pad()用值将数组填补到指定长度。 4

array_pop()将数组最后一个单元弹出(出栈)。 4

array_product()计算数组中所有值的乘积。 5

array_push()将一个或多个单元(元素)压入数组的末尾(入栈)。 4

array_rand()从数组中随机选出一个或多个元素,并返回。 4

array_reduce()用回调函数迭代地将数组简化为单一的值。 4

array_reverse()将原数组中的元素顺序翻转,创建新的数组并返回。 4

array_search()在数组中搜索给定的值,如果成功则返回相应的键名。 4

array_shift()删除数组中的第一个元素,并返回被删除元素的值。 4

array_slice()在数组中根据条件取出一段值,并返回。 4

array_splice()把数组中的一部分去掉并用其它值取代。 4

array_sum()计算数组中所有值的和。 4

array_udiff()用回调函数比较数据来计算数组的差集。 5

array_udiff_assoc()带索引检查计算数组的差集,用回调函数比较数据。 5

array_udiff_uassoc()带索引检查计算数组的差集,用回调函数比较数据和索引。 5

array_uintersect()计算数组的交集,用回调函数比较数据。 5

array_uintersect_assoc()带索引检查计算数组的交集,用回调函数比较数据。 5

array_uintersect_uassoc()带索引检查计算数组的交集,用回调函数比较数据和索引。 5

array_unique()删除数组中重复的值。 4

array_unshift()在数组开头插入一个或多个元素。 4

array_values()返回数组中所有的值。 4

array_walk()对数组中的每个成员应用用户函数。 3

array_walk_recursive()对数组中的每个成员递归地应用用户函数。 5

arsort()对数组进行逆向排序并保持索引关系。 3

asort()对数组进行排序并保持索引关系。 3

compact()建立一个数组,包括变量名和它们的值。 4

count()计算数组中的元素数目或对象中的属性个数。 3

current()返回数组中的当前元素。 3

each()返回数组中当前的键/值对并将数组指针向前移动一步。 3

end()将数组的内部指针指向最后一个元素。 3

extract()从数组中将变量导入到当前的符号表。 3

in_array()检查数组中是否存在指定的值。 4

key()从关联数组中取得键名。 3

krsort()对数组按照键名逆向排序。 3

ksort()对数组按照键名排序。 3

list()把数组中的值赋给一些变量。 3

natcasesort()用“自然排序”算法对数组进行不区分大小写字母的排序。 4

natsort()用“自然排序”算法对数组排序。 4

next()将数组中的内部指针向前移动一位。 3

pos() current()的别名。 3

prev()将数组的内部指针倒回一位。 3

range()建立一个包含指定范围的元素的数组。 3

reset()将数组的内部指针指向第一个元素。 3

rsort()对数组逆向排序。 3

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

sizeof() count()的别名。 3

sort()对数组排序。 3

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

uksort()使用用户自定义的比较函数对数组中的键名进行排序。 3

usort()使用用户自定义的比较函数对数组中的值进行排序。 3

文章分享结束,php数组排序函数和php高级程序员的答案你都知道了吗?欢迎再次光临本站哦!

小学生如何自学编程 小学生有必要学编程吗javacms开源免费(免费javaweb源码)