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