찾다
일일 프로그램PHP 지식PHP 버블 정렬 알고리즘 (1)



이전 글에서는 PHP 알고리즘 시리즈 "PHP Random Picking Algorithm"을 소개해 드렸습니다. 오늘 우리는 일반적인 PHP 알고리즘 시리즈, 즉 PHP Bubble Sort Algorithm의 관련 지식 포인트를 계속해서 설명하겠습니다.

PHP 버블 정렬 알고리즘 (1)

버블 정렬은 프로그래머에게 낯선 것이 아니라고 생각합니다. 버블 정렬 알고리즘은 단순히 인접한 두 숫자를 순서대로 비교한 다음 마지막 두 자리까지 크기에 따라 정렬합니다.

이를 "버블 정렬" 알고리즘이라고 부르는 이유는 탄산 음료의 이산화탄소 거품이 회전하는 것처럼 더 큰 요소가 교환을 통해 배열의 맨 위로 천천히 "부유"하기 때문입니다(오름차순 또는 내림차순). 결국 배열의 상단으로 이동합니다. 상단과 동일합니다.

이제 구체적인 코드 예제를 기반으로 PHP 버블 정렬 알고리즘 구현을 소개하겠습니다. (다음은 오름차순, 즉 작은 것부터 큰 것까지)

코드 예시는 다음과 같습니다.

<?php
function maopao($arr){
    $len = count($arr);
    for($k=0;$k<=$len;$k++)
    {
        for($j=$len-1;$j>$k;$j--){
            if($arr[$j]<$arr[$j-1]){
                $temp = $arr[$j];
                $arr[$j] = $arr[$j-1];
                $arr[$j-1] = $temp;
            }
        }
    }
    return $arr;
}
$arr = [2,6,2,8,2,34,5,9,2341,23];

var_dump(maopao($arr));

여기서 maopao 메소드를 정의합니다. 먼저, 지정된 배열의 전체 길이를 다음과 같이 계산합니다. 카운트 기능. 그런 다음 이중 for 루프 문을 사용하여 배열 요소를 반복하고 하나씩 비교합니다. 그런 다음 외부 for 루프는 루프 라운드를 제어하는 ​​데 사용됩니다. 내부 for 루프는 각 라운드의 비교 횟수를 제어하고 선택합니다. 각 비교 라운드 후에 가장 큰 값이 마지막에 배치됩니다.

Note: 여기에서는 임시 변수 $temp Medium을 통해 $j의 값을 저장하여 루프에서 인접한 두 요소를 비교하고 끝에 더 큰 값을 넣습니다.

출력:

array (size=10)
  0 => int 2
  1 => int 2
  2 => int 2
  3 => int 5
  4 => int 6
  5 => int 8
  6 => int 9
  7 => int 23
  8 => int 34
  9 => int 2341

버블 정렬의 알고리즘 원리를 요약합니다. 데이터 집합에 대해 인접한 데이터의 크기를 비교하여 값이 작은 데이터를 앞에 배치하고 값이 큰 데이터를 뒤에 배치합니다. .

이 글은 PHP 버블 정렬 알고리즘에 대한 소개입니다. 다음 글 "PHP 버블 정렬 알고리즘 (2)"에서는 Xdebug를 사용하여 버블 정렬 알고리즘 구현 과정을 보다 직관적으로 디버깅하고 실행할 수 있도록 도와드리겠습니다. .



위 내용은 PHP 버블 정렬 알고리즘 (1)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기