찾다
일일 프로그램PHP 지식선택 정렬 알고리즘의 상세 분석

선택 정렬

선택 정렬은 가장 안정적인 정렬 알고리즘 중 하나입니다. 사용 시 데이터 크기가 작을수록 좋습니다. 이론적으로 말하면, 선택 정렬은 대부분의 사람들이 정렬할 때 생각하는 가장 일반적인 방법일 수도 있습니다.

선택 정렬은 간단하고 직관적인 정렬 알고리즘입니다. 작동 방식은 다음과 같습니다.

배열을 반복하면서 배열에서 최대값과 위치를 찾습니다. 그런 다음 최대값이 있는 단위의 위치를 ​​배열의 마지막 단위와 "교환"합니다. 이 작업을 수행한 후 배열의 최대값을 마지막 위치에 배치해야 합니다.

위 과정에서 남은 데이터를 계속해서 순회하면서 동일한 작업을 수행합니다. 이때 나머지 부분의 최대값은 전체적으로 두 번째 위치인 나머지 부분의 마지막 위치에 배치될 수도 있습니다. .

그리고 등등. . . . . .

그림:

원래 배열
18 22
12 15 23
9
첫 번째 여행 18
22 12 15 9 23
두 번째 여행 18 9 12 15 22 2 3
세 번째 여행 15 9 12 18 22 23
네번째 여행 12 9 15 18 22 2 3
다섯 번째 여행 9 12 15 18 22 23

코드는 다음과 같습니다.

<?php
        $arr1 = array(18,22,12,15,23,9);
        $n = count($arr1);
        for ($i=0; $i < $n-1; $i++) { 
            //找最大值
            $max = $arr1[0];
            $max_key = 0;
            for ($k=0; $k < $n - $i; $k++) { 
                if ($arr1[$k] > $max) {
                    $max = $arr1[$k];
                    $max_key = $k;
                }
            }
            //交换
            $temp = $arr1[$max_key];
            $arr1[$max_key] = $arr1[$n-1-$i];
            $arr1[$n-1-$i] = $temp;
        }

규칙 요약:

1. 가장 큰 것을 찾으려면 시작부터 끝 값(및 아래 첨자), 교환 횟수는 $n-1, $n은 배열 길이입니다.

2. 매번 해야 할 일은: a) 최대값을 찾는 것입니다. 이번 여행의 마지막 항목으로 최대값을 추가합니다.

3. 각 여행의 최대값을 찾기 위한 데이터 수는 이전 여행보다 1개 적으며, 첫 번째 여행에는 $n이 있습니다.



위 내용은 선택 정렬 알고리즘의 상세 분석의 상세 내용입니다. 자세한 내용은 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. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

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