首頁 >後端開發 >PHP問題 >在PHP中如何使用冒泡排序?

在PHP中如何使用冒泡排序?

慕斯
慕斯原創
2021-06-15 17:54:592087瀏覽

上篇文章為大家介紹了《PHP中什麼是錯誤處理?錯誤代號?錯誤觸發? 》,本文繼續介紹在PHP中如何使用冒泡排序?有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。

在PHP中如何使用冒泡排序?

陣列排序演算法.

冒泡排序

冒泡排序(Bubble Sort),是一種計算機科學領域的較簡單的排序演算法。

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

走訪數列的工作是重複地進行直到沒有再需要交換,也就是說該數列已經排序完成

冒泡排序的演算法思路:。

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

2)對每一對相鄰元素作同樣的工作,從開始第-對到結尾的最後一對。在這一點,最後的元素應該會是最大的數。

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

4)持續每次對越來越少的元素重複上面的步驟,直到沒有任何一對數字需要比較。

首先我們先定義一個數組,然後我們想辦法把最大的值放在最右邊去,我們使用for循環,我們以程式碼為例,如下:

<?php 
//数组排序算法:冒泡排序
$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 &#39;<pre class="brush:php;toolbar:false">&#39;;
print_r($arr);

運行結果如下:

在PHP中如何使用冒泡排序?

那麼此時我們該如何讓上述程式碼在執行一次,我們讓下面可以每次找出最大值的程式碼重複執行。

<?php 
//数组排序算法:冒泡排序
$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 &#39;<pre class="brush:php;toolbar:false">&#39;;
print_r($arr);
}

運行結果如下:

在PHP中如何使用冒泡排序?

推薦學習:《PHP影片教學

以上是在PHP中如何使用冒泡排序?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn