用PHP實現一些常見的排序算法

一、冒泡排序:數組

兩兩相比,每循環一輪就不用再比較最後一個元素了,由於最後一個元素已是最大或者最小。spa

function maopaoSort ($list)
{
    $len = count($list);
    for ($i = 0; $i < $len - 1; $i++) {
        for ($j = 0; $j < $len - $i - 1; $j++) {
            if ($list[$j] > $list[$j + 1]) {
                $tmp = $list[$j];
                $list[$j] = $list[$j + 1];
                $list[$j + 1] = $tmp;
            }
        }
    }
    return $list;
}

二、選擇排序:code

選定一個做爲基本值,剩下的和這個比較,而後調換位置。blog

function xuanzeSort ($list)
{
    $len = count($list);
    for ($i = 0; $i < $len - 1; $i++) {
        $pos = $i;
        for ($j = $i + 1; $j < $len; $j++) {
            if ($list[$pos] > $list[$j]) {
                $pos = $j;
            }
        }
        if ($pos != $i) {
            $tmp = $list[$pos];
            $list[$pos] = $list[$i];
            $list[$i] = $tmp;
        }
    }
    return $list;
}

三、快速排序:排序

原理就是拿出一個標尺值,而後分爲左右兩個數組,分別對比遞歸

function kuaisuSort ($list)
{
    $len = count($list);
    if ($len <= 1) {//遞歸出口
        return $list;
    }
    $base = $list[0];//選擇一個比較值
    $leftList = $rightList = [];
    for ($i = 1; $i < $len; $i++) {
        if ($base > $list[$i]) {
            $leftList[] = $list[$i];
        } else {
            $rightList[] = $list[$i];
        }
    }
    //遞歸分別再處理左右兩邊的數組
    $leftList = kuaisuSort($leftList);
    $rightList = kuaisuSort($rightList);
    return array_merge($leftList, [$base], $rightList);
}

四、插入排序:io

假設前面的數都是排好順序的,要把第n個數插入到有序裏function

function charuSort ($list)
{
    $len = count($list);
    for ($i = 1; $i < $len; $i++) {
        $tmp = $list[$i];//獲取對比元素
        for ($j = $i - 1; $j > 0; $j--) {
            if ($list[$j] > $tmp) {
                $list[$j + 1] = $list[$j];
                $list[$j] = $tmp;
            } else {
                break;
            }
        }
    }
    return $list;
}
相關文章
相關標籤/搜索