|
復(fù)制代碼 代碼如下:
<?php
class='pingjiaF' frameborder='0' src='http://www.jb51.NET' scrolling='no'>
對(duì)數(shù)組排序
usort() 函數(shù)使用用戶自定義的函數(shù)對(duì)數(shù)組排序。
*/
function cmp($a, $b) //用戶自定義回調(diào)函數(shù)
{
if($a==$b) //如果兩個(gè)參數(shù)相等
{
return 0; //返回0
}
return($a>$b)?-1:1; //如果第1個(gè)參數(shù)大于第2個(gè)返回1,否則-1
}
$a=array(3,2,5,6,1); //定義一個(gè)數(shù)組
usort ($a,"cmp"); //使用自定義函數(shù)對(duì)數(shù)組排序
foreach($a as $key=>$value) //循環(huán)輸出排序后的鍵值對(duì)
{
echo "$key:$valuen";
}
/*
注釋:如果兩個(gè)元素比較結(jié)果相同,則它們?cè)谂判蚝蟮臄?shù)組中的順序未經(jīng)定義。到 php 4.0.6 之前,用戶自定義函數(shù)將保留這些元素的原有順序。但是由于在 4.1.0 中引進(jìn)了新的排序算法,結(jié)果將不是這樣了,因?yàn)閷?duì)此沒(méi)有一個(gè)有效的解決方案。
*/
//對(duì)數(shù)組鍵名排序 uksort(array,sorttype)
function cmp($a, $b) //用戶自定義回調(diào)函數(shù)
{
if($a==$b) //如果兩個(gè)參數(shù)相等
{
return 0; //返回0
}
return($a>$b)?-1:1; //如果第1個(gè)參數(shù)大于第2個(gè)返回1,否則-1
}
$a=array(4=>"four",3 =>"three",20 =>"twenty",10=>"ten"); //定義一個(gè)數(shù)組
uksort ($a,"cmp"); //使用自定義函數(shù)對(duì)數(shù)組鍵名排序
foreach($a as $key=>$value) //循環(huán)輸出排序后的鍵值對(duì)
{ // www.jbxue.com
echo "$key:$valuen";
}/*
uksort() 函數(shù)使用用戶自定義的比較函數(shù)按照鍵名對(duì)數(shù)組排序,并保持索引關(guān)系。
如果成功則返回 true,否則返回 false。
如果要排序的數(shù)組需要用一種不尋常的標(biāo)準(zhǔn)進(jìn)行排序,那么應(yīng)該使用此函數(shù)。
自定義函數(shù)應(yīng)接受兩個(gè)參數(shù),該參數(shù)將被數(shù)組中的一對(duì)鍵名填充。比較函數(shù)在第一個(gè)參數(shù)小于,等于,或大于第二個(gè)參數(shù)時(shí)必須分別返回一個(gè)小于零,等于零,或大于零的整數(shù)。
*/
/*
sort() 函數(shù)按升序?qū)o定數(shù)組的值排序。
注釋:本函數(shù)為數(shù)組中的單元賦予新的鍵名。原有的鍵名將被刪除。
如果成功則返回 true,否則返回 false。
*/
$fruits=array("lemon","orange","banana","apple"); //定義一個(gè)數(shù)組
sort($fruits); //對(duì)數(shù)組進(jìn)行排序
foreach($fruits as $key=>$val) //循環(huán)輸出數(shù)組排序后的鍵值對(duì)
{
echo "$key=$valn"; //輸出鍵值對(duì)
}
php技術(shù):php對(duì)數(shù)組排序的簡(jiǎn)單實(shí)例,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。