復制代碼 代碼如下:
<?php
class='pingjiaF' frameborder='0' src='http://www.jb51.net' scrolling='no'>
對數組排序
usort() 函數使用用戶自定義的函數對數組排序。
*/
function cmp($a, $b) //用戶自定義回調函數
{
if($a==$b) //如果兩個參數相等
{
return 0; //返回0
}
return($a>$b)?-1:1; //如果第1個參數大於第2個返回1,否則-1
}
$a=array(3,2,5,6,1); //定義一個數組
usort ($a,"cmp"); //使用自定義函數對數組排序
foreach($a as $key=>$value) //循環輸出排序後的鍵值對
{
echo "$key:$valuen";
}
/*
注釋:如果兩個元素比較結果相同,則它們在排序後的數組中的順序未經定義。到 php 4.0.6 之前,用戶自定義函數將保留這些元素的原有順序。但是由於在 4.1.0 中引進了新的排序算法,結果將不是這樣了,因為對此沒有一個有效的解決方案。
*/
//對數組鍵名排序 uksort(array,sorttype)
function cmp($a, $b) //用戶自定義回調函數
{
if($a==$b) //如果兩個參數相等
{
return 0; //返回0
}
return($a>$b)?-1:1; //如果第1個參數大於第2個返回1,否則-1
}
$a=array(4=>"four",3 =>"three",20 =>"twenty",10=>"ten"); //定義一個數組
uksort ($a,"cmp"); //使用自定義函數對數組鍵名排序
foreach($a as $key=>$value) //循環輸出排序後的鍵值對
{ // www.jb51.net
echo "$key:$valuen";
}/*
uksort() 函數使用用戶自定義的比較函數按照鍵名對數組排序,並保持索引關系。
如果成功則返回 true,否則返回 false。
如果要排序的數組需要用一種不尋常的標准進行排序,那麼應該使用此函數。
自定義函數應接受兩個參數,該參數將被數組中的一對鍵名填充。比較函數在第一個參數小於,等於,或大於第二個參數時必須分別返回一個小於零,等於零,或大於零的整數。
*/
/*
sort() 函數按升序對給定數組的值排序。
注釋:本函數為數組中的單元賦予新的鍵名。原有的鍵名將被刪除。
如果成功則返回 true,否則返回 false。
*/
$fruits=array("lemon","orange","banana","apple"); //定義一個數組
sort($fruits); //對數組進行排序
foreach($fruits as $key=>$val) //循環輸出數組排序後的鍵值對
{
echo "$key=$valn"; //輸出鍵值對
}