>  기사  >  백엔드 개발  >  PHP에서 일반 정렬을 구현하는 방법

PHP에서 일반 정렬을 구현하는 방법

醉折花枝作酒筹
醉折花枝作酒筹앞으로
2021-06-03 17:30:382037검색

이 글에서는 PHP에서 일반적인 정렬을 구현하는 방법을 소개합니다. 도움이 필요한 친구들이 모두 참고할 수 있기를 바랍니다.

PHP에서 일반 정렬을 구현하는 방법

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

버블 정렬

function maopao($arr)
{
    $len = count($arr);
    for ($i=1; $i <$len ; $i++) { 
        # code...
        for ($k=0; $k <($len-$i) ; $k++) { 
            # code...
            if ($arr[$k]>$arr[$k+1]) {
                # code...
                $v_k = $arr[$k];
                $arr[$k]=$arr[$k+1];
                $arr[$k+1]=$v_k;    
            }
        }
    }
    return $arr;
}

빠른 정렬

function kuaisu($arr)
{
    $len = count($arr);
    if ($len<=1) {
        # code...
        return $arr;
    }
    //选择基准元素
    $a = $arr[0];
    $left = $right = [];
    //循环
    for ($i=1; $i < $len; $i++) { 
        # code...
        if ($arr[$i]<$a) {
            # code...
            $left[]=$arr[$i];
        }else{
            $right[]=$arr[$i];
        }
    }
    $left = kuaisu($left);
    $right = kuaisu($right);
    return array_merge($left,[$a],$right);
}

삽입 정렬

function insertSort($arr)
{
    $len = count($arr);
    for ($i=1; $i < $len; $i++) { 
        # code...
        $tmp = $arr[$i];
        for ($j=$i-1; $j >=0 ; $j--) { 
            # code...
            if ($tmp<$arr[$j]) {
                    # code...
                $arr[$j+1]=$arr[$j];
                $arr[$j]=$tmp;    
            }else{
                break;
            }    
        }
    }
    return $arr;
    }

선택 정렬

function selectSort($arr)
{
    $len = count($arr);

    for ($i=0; $i < $len; $i++) { 
        # code...
        $p=$i;

        for ($j=$i+1; $j < $len; $j++) { 
            # code...
            if ($arr[$p]>$arr[$j]) {
                # code...
                $p=$j;
            }

        }

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

    }

    return $arr;
}

추천 학습: php 비디오 튜토리얼

위 내용은 PHP에서 일반 정렬을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 segmentfault.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제