【冒泡排序:從后向前,依次比較相鄰元素的排序碼,若 " /> heyzo一本久久综合,中文字幕 在线观看,亚洲精品一线二线三线无人区

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

php中的一些數組排序方法分享

A.內部排序(直接加載到內存進行排序):包括交換式排序(冒泡和快速法)、選擇式排序、插入式排序
B.外部排序(因數據量大,需借助外部存儲進行排序):包括合并排序、直接合并排序

【冒泡排序:從后向前,依次比較相鄰元素的排序碼,若發現逆序則交換,一輪結束后,再來一輪,直到所有相鄰數無逆序,即按順序排完】
復制代碼 代碼如下:
function maoPao($arr,$style)//【默認傳遞的是值,不是地址。如果在$arr前加個&,則和$arr1指向同一個地址,函數外的$arr1也被排好了】
{
$temp=0;
$flag=false;
for($i=0;$i<count($arr)-1;$i++)
{
for($j=0;$j<count($arr)-1-$i;$j++)
{
if($style=='bts') $op=$arr[$j]<$arr[$j+1];
else if($style=='stb') $op=$arr[$j]>$arr[$j+1];
if($op)
{
$temp=$arr[$j];
$arr[$j]=$arr[$j+1];
$arr[$j+1]=$temp;
$flag=true;
}
}
if($flag==false)
{
break;//當一次橫向循環下來flag==false;說明縱向循環里每次相鄰元素比較大小時if條件均不滿足,即從小到大已排好,無需再橫向循環
}
}
foreach ($arr as $key => $value)
{
echo $value.',';
}
}
$arr1=array(101,101,-9,-8,0,76,1,57,43,90,23,-56);
maoPao($arr1,'stb');//small to big

【選擇排序:第二個數至第n個數分別與第一個數比較,進行交換,第三個數至第n個數分別與第二個數比較,進行交換,直到排完】
復制代碼 代碼如下:
function selectSort($arr,$style)
{
$temp=0;
$flag=false;
for($i=0;$i<count($arr)-1;$i++)
{
for($j=$i+1;$j<count($arr);$j++)
{
if($style=='bts') $op=$arr[$i]<$arr[$j];
else if($style=='stb') $op=$arr[$i]>$arr[$j];
if($op)
{
$temp=$arr[$i];
$arr[$i]=$arr[$j];
$arr[$j]=$temp;
$flag=true;
}
}
if($flag==false)
{
break;
}
}
foreach ($arr as $key => $value)
{
echo $value.',';
}
}
$arr1=array(21.5,33,90,7,-4,5,55,11);
selectSort($arr1,'stb');

復制代碼 代碼如下:
function selectSort($arr,$style)
{
$temp=0;
$flag=false;
for($i=0;$i<count($arr)-1;$i++)
{
for($j=$i+1;$j<count($arr);$j++)
{
if($style=='bts') $op=$arr[$i]<$arr[$j];
else if($style=='stb') $op=$arr[$i]>$arr[$j];
if($op)
{
$temp=$arr[$i];
$arr[$i]=$arr[$j];
$arr[$j]=$temp;
$flag=true;
}
}
if($flag==false)
{
break;
}
}
foreach ($arr as $key => $value)
{
echo $value.',';
}
}
$arr1=array(21.5,33,90,7,-4,5,55,11);
selectSort($arr1,'stb');
echo "<br/>";

php技術php中的一些數組排序方法分享,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 长垣县| 阜南县| 多伦县| 称多县| 西林县| 漾濞| 云浮市| 连州市| 张北县| 田林县| 新昌县| 山西省| 台山市| 厦门市| 策勒县| 山东省| 望谟县| 姚安县| 南平市| 梅州市| 芷江| 高雄市| 临海市| 怀集县| 西平县| 岚皋县| 许昌市| 綦江县| 武平县| 固原市| 八宿县| 木兰县| 精河县| 防城港市| 沈丘县| 阿克陶县| 涡阳县| 宜宾市| 册亨县| 荣昌县| 桂阳县|