您好,登錄后才能下訂單哦!
本篇內容介紹了“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 '<pre>'; print_r($arr);
運行結果如下:
那么此時我們該如何讓上述代碼在運行一次,我們讓下面可以每次找出最大值的代碼重復執行。
<?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 '<pre>'; print_r($arr); }
運行結果如下:
“PHP中使用冒泡排序的方法”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。