> 백엔드 개발 > PHP 문제 > 함수 없이 PHP 배열 정렬

함수 없이 PHP 배열 정렬

WBOY
풀어 주다: 2023-05-19 09:13:37
원래의
654명이 탐색했습니다.

PHP에서 배열은 여러 값을 저장하고 인덱싱을 통해 이러한 값에 액세스할 수 있는 일반적인 데이터 유형입니다. 배열을 정렬해야 할 때, 우리는 일반적으로 배열을 쉽게 정렬할 수 있게 해주는 sort(), rsort(), asort() 등과 같은 PHP 내장 함수를 사용합니다.

그러나 때로는 정렬 기능을 사용하지 않고 배열을 정렬해야 할 수도 있습니다. 이는 다음 상황에서 발생할 수 있습니다.

  1. 정렬 함수의 콜백 함수를 사용하여 배열을 사용자 정의 정렬하는 것은 비효율적입니다.
  2. 코드 가독성과 성능을 향상시키기 위해 PHP 내장 함수를 사용하지 않기를 바랍니다.

이 경우 PHP에서 배열을 어떻게 정렬할 수 있나요? 이 기사에서는 기본 PHP 언어를 기반으로 하는 몇 가지 배열 정렬 방법을 소개합니다.

  1. 버블 정렬

버블 정렬은 인접한 요소를 비교하고 교환하여 배열을 정렬하는 기본 정렬 알고리즘입니다. 구체적인 구현은 다음과 같습니다.

function array_bubble_sort($arr){
    $len=count($arr);
    for($i=0;$i<$len-1;$i++){
        for($j=0;$j<$len-1-$i;$j++){
            if($arr[$j]>$arr[$j+1]){
                $temp=$arr[$j+1];
                $arr[$j+1]=$arr[$j];
                $arr[$j]=$temp;
            }
        }
    }
    return $arr;
}
로그인 후 복사

위 코드에서는 두 개의 for 루프를 사용합니다. 외부 루프는 비교 횟수를 제어하고 내부 루프는 인접한 요소를 비교하고 교환하는 데 사용됩니다. 이 방법으로 정렬 함수를 사용하지 않고도 배열을 정렬할 수 있습니다.

  1. 삽입 정렬

삽입 정렬은 정렬된 배열에 각 요소를 하나씩 삽입하여 배열을 정렬하는 간단하고 효과적인 정렬 알고리즘입니다. 구체적인 구현은 다음과 같습니다:

function array_insertion_sort($arr){
    $len=count($arr);
    for($i=1;$i<$len;$i++){
        $temp=$arr[$i];
        $j=$i-1;
        while($j>=0&&$arr[$j]>$temp){
            $arr[$j+1]=$arr[$j];
            $j--;
        }
        $arr[$j+1]=$temp;
    }
    return $arr;
}
로그인 후 복사

위 코드에서는 for 루프와 while 루프를 사용하여 삽입할 요소를 선택하고 while 루프를 사용하여 올바른 요소에 삽입합니다. 위치. 또한 이 방법을 사용하면 정렬 기능을 사용하지 않고도 배열을 정렬할 수 있습니다.

  1. Quick Sort

Quick Sort는 배열을 두 개의 하위 배열로 나누어 정렬하는 일반적으로 사용되는 정렬 알고리즘입니다. 구체적인 구현은 다음과 같습니다.

function array_quick_sort($arr){
    $len=count($arr);
    if($len<=1){
        return $arr;
    }
    $pivot=$arr[0];
    $left=[];
    $right=[];
    for($i=1;$i<$len;$i++){
        if($arr[$i]<=$pivot){
            $left[]=$arr[$i];
        }else{
            $right[]=$arr[$i];
        }
    }
    return array_merge(array_quick_sort($left),[$pivot],array_quick_sort($right));
}
로그인 후 복사

위 코드에서는 재귀를 사용하여 빠른 정렬을 구현했습니다. 먼저 피벗 요소를 피벗으로 선택한 다음 배열을 반복하여 작은 요소를 왼쪽 하위 배열에, 큰 요소를 오른쪽 하위 배열에 넣은 다음 재귀를 통해 왼쪽 및 오른쪽 하위 배열을 정렬합니다. 그리고 마지막으로 기본 요소와 병합됩니다. 마찬가지로, sort 함수를 사용하지 않고도 배열을 정렬하는 것이 가능합니다.

요약

위의 세 가지 정렬 알고리즘은 정렬 기능을 사용하지 않고도 PHP 배열을 정렬할 수 있습니다. 이러한 알고리즘은 PHP에 내장된 정렬 기능만큼 효율적이지는 않지만 코드의 가독성과 이해력을 향상시킬 수 있습니다. 사용자 정의 정렬 방법이 필요하거나 PHP 내장 함수를 사용하지 않는 경우 이러한 알고리즘을 사용하여 배열을 정렬해 보세요.

위 내용은 함수 없이 PHP 배열 정렬의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿