溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

PHP中使用冒泡排序的方法

發(fā)布時間:2021-06-16 09:44:51 來源:億速云 閱讀:409 作者:chen 欄目:編程語言

本篇內(nèi)容介紹了“PHP中使用冒泡排序的方法”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

數(shù)組排序算法.

冒泡排序

冒泡排序(Bubble Sort),是一種計(jì)算機(jī)科學(xué)領(lǐng)域的較簡單的排序算法。

它重復(fù)地走訪邊要排序的數(shù)列,-次比較兩個元素,如果他們的順序錯誤就把他們交換過來。

走訪數(shù)列的工作是重復(fù)地進(jìn)行直到?jīng)]有再需要交換,也就是說該數(shù)列已經(jīng)排序完成

冒泡排序的算法思路:。

1)比較相鄰的元素。 如果第一一個比第二個大,就交換他們兩個。。

2)對每一對相鄰元素作同樣的工作,從開始第-對到結(jié)尾的最后一對。在這一點(diǎn),最后的元素應(yīng)該會是最大的數(shù)。

3)針對所有的元素重以上的步驟,除了最后一個。。

4)持續(xù)每次對越來越少的元素重復(fù)上面的步驟,直到?jīng)]有任何一對數(shù)字需要比較。

首先我們先定義一個數(shù)組,然后我們想辦法把最大的值放在最右邊去,我們使用for循環(huán),我們以代碼為例,如下:

<?php 
//數(shù)組排序算法:冒泡排序
$arr = array(1,4,2,9,7,5,8);
//想辦法將最大的值放到最右邊去
for($j =0,$len = count($arr); $j < $len - 1;$j++){
//判斷:兩兩相比
if($arr[$j] > $arr[$j+1]){
//左邊比右邊大:交換
$temp = $arr[$j];
$arr[$j] = $arr[$j+1];
$arr[$j+1] = $temp;
 }
}
echo '<pre>';
print_r($arr);

運(yùn)行結(jié)果如下:

PHP中使用冒泡排序的方法

那么此時我們該如何讓上述代碼在運(yùn)行一次,我們讓下面可以每次找出最大值的代碼重復(fù)執(zhí)行。

<?php 
//數(shù)組排序算法:冒泡排序
$arr = array(1,4,2,9,7,5,8);
for($i=0,$len = count($arr);$i < $len;$i++){
//想辦法將最大的值放到最右邊去
for($j =0,$len = count($arr); $j < $len - 1;$j++){
//判斷:兩兩相比
if($arr[$j] > $arr[$j+1]){
//左邊比右邊大:交換
$temp = $arr[$j];
$arr[$j] = $arr[$j+1];
$arr[$j+1] = $temp;
 }
}
echo '<pre>';
print_r($arr);
}

運(yùn)行結(jié)果如下:

PHP中使用冒泡排序的方法

“PHP中使用冒泡排序的方法”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI