MySQL 冒泡算法是一種簡單的排序算法,它的名稱來自于當數據類似一個水泡在水中升上水面時的叫聲。這個算法的基本思想是反復地交換相鄰的未按順序排列的元素,由于排序的過程中最大的元素像氣泡一樣逐漸從底部浮到頂部,而最小的元素則會經過多次下沉后被交換到底部。
function bubbleSort(array $arr): array { $length = count($arr); for ($i = 0; $i< $length - 1; $i++) { for ($j = 0; $j< $length - $i - 1; $j++) { if ($arr[$j] >$arr[$j + 1]) { //交換位置 $temp = $arr[$j]; $arr[$j] = $arr[$j + 1]; $arr[$j + 1] = $temp; } } } return $arr; }
在這段代碼中,我們使用了兩重循環,外層循環用于控制排序的輪數,內層循環用于比較相鄰元素并交換位置,每完成一輪排序,最大的元素就被交換到了數組的最后一個位置。這個算法的時間復雜度為 O(n2),對于小規模的數據排序效果很好,但是對于大規模的數據排序則效率較低。
上一篇mysql 內部重啟