時間複雜度為 O (n^2) 的排序演算法

iyoungm發表於2018-10-23

今天練習時間複雜度為 O(n^2) 的排序演算法

定義陣列

$arr = [4,5,6,3,2,1];

$length = count($arr);

氣泡排序

file

for ($i = 0; $i < $length; $i++) {  //迴圈次數

    $change = false;  //資料是否有交換

    for ($j = 0; $j < $length - $i - 1 ; $j++) {
        if ($arr[$j] > $arr[$j + 1]) {
            $tmp = $arr[$j];
            $arr[$j] = $arr[$j + 1];
            $arr[$j + 1] = $tmp;
            $change = true;
        }
    }

    if (!$change) {
        break;
    }
}

插入排序

file
file

for ($i = 1; $i < $length; $i++) {
    $value = $arr[$i];
    for ($j = $i - 1; $j >= 0; $j--) {
        if ($arr[$j] > $value) {
            $arr[$j + 1] = $arr[$j];
        } else {
            break;
        }
    }
    $arr[$j + 1] = $value;
}

選擇排序

file

for ($i = 0; $i < $length; $i++) {
    $minIndex = $i; //最小值的下標預設為 `i`

    for ($j = $length - 1; $j > $i; $j--) {
        if ($arr[$j] < $arr[$minIndex]) {
            $minIndex = $j;   //最小值下標
        }
    }

    $tmp = $arr[$i];
    $arr[$i] = $arr[$minIndex];
    $arr[$minIndex] = $tmp;

}

相關文章