> Java > java지도 시간 > Java 선택 정렬 알고리즘의 구현 방법에 대한 자세한 설명

Java 선택 정렬 알고리즘의 구현 방법에 대한 자세한 설명

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2024-02-20 10:47:06
원래의
1179명이 탐색했습니다.

Java 선택 정렬 알고리즘의 구현 방법에 대한 자세한 설명

Java 선택 정렬 코드 세부 설명 및 구현 방법

선택 정렬은 모든 데이터가 나올 때까지 가장 작은(또는 가장 큰) 요소를 시퀀스의 시작 부분에 선택하는 간단하고 직관적인 정렬 알고리즘입니다. 정렬할 요소가 소진되었습니다. 선택 정렬 방법의 가장 큰 장점은 아이디어가 간단하고 구현이 용이하며 추가 저장 공간이 필요하지 않아 일부 간단한 정렬 문제에서 좋은 성능을 보인다는 것입니다.

아래에서는 선택 정렬 방법의 구현 방법을 자세히 설명하고 구체적인 Java 코드 예제를 제공합니다.

선택 정렬 방법 구현 방법:

  1. 정렬할 시퀀스에서 가장 작은(가장 큰) 요소를 찾아 시퀀스의 시작 위치에 배치합니다.
  2. 정렬되지 않은 나머지 요소 중에서 가장 작은(가장 큰) 요소를 계속 찾아 정렬된 시퀀스의 마지막에 배치합니다.
  3. 모든 요소가 정렬될 때까지 2단계를 반복하세요.

Java 코드 예:

public class SelectionSort {
    public static void selectionSort(int[] arr) {
        int n = arr.length;
        for (int i = 0; i < n-1; i++) {
            int min_idx = i;
            for (int j = i+1; j < n; j++) {
                if (arr[j] < arr[min_idx]) {
                    min_idx = j;
                }
            }
            int temp = arr[min_idx];
            arr[min_idx] = arr[i];
            arr[i] = temp;
        }
    }

    public static void main(String[] args) {
        int[] arr = {64, 25, 12, 22, 11};
        selectionSort(arr);
        System.out.println("排序后的数组:");
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
    }
}
로그인 후 복사

실행 결과는 다음과 같습니다. 11 12 22 25 64

위 코드에서는 SelectionSort라는 정적 메서드가 포함된 SelectionSort라는 클래스를 정의합니다. 이 클래스는 다음과 같이 정수 배열을 받습니다. 매개변수를 선택하고 정렬을 위해 선택합니다. 기본 메소드에서는 정수 배열 arr을 정의하고 SelectionSort 메소드를 호출하여 이를 정렬합니다. 마지막으로 루프를 통해 정렬된 배열을 인쇄합니다.

선택 정렬 방법의 시간 복잡도는 O(n^2)입니다. 여기서 n은 정렬할 시퀀스의 길이입니다. 이는 대규모 데이터를 정렬하는 데 선택 정렬 방법의 효율성을 떨어뜨립니다. 그러나 일부 소규모 또는 부분적으로 정렬된 데이터 정렬 문제에서는 선택 정렬 방법이 여전히 매우 잘 수행될 수 있습니다.

위 내용은 Java 선택 정렬 알고리즘의 구현 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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