> Java > java지도 시간 > 본문

Java의 병합 정렬 알고리즘의 원리와 구현 방법

PHPz
풀어 주다: 2023-04-19 17:43:16
앞으로
887명이 탐색했습니다.

    1. 기본 개념

    병합 정렬은 병합 연산을 기반으로 하는 효과적인 정렬 알고리즘입니다. 이 알고리즘은 분할 정복(Divide and Conquer) 방식을 사용하는 매우 일반적인 응용 프로그램입니다. 이미 정렬된 하위 시퀀스를 병합하여 완전히 정렬된 시퀀스를 얻습니다. 즉, 먼저 각 하위 시퀀스를 순서대로 만든 다음 하위 시퀀스 세그먼트를 순서대로 만듭니다. 두 개의 순서 목록이 하나의 순서 목록으로 병합되는 경우 이를 양방향 병합이라고 합니다.

    2. 알고리즘 분석

    1. 알고리즘 설명

    길이가 n/2인 두 개의 하위 시퀀스로 분할합니다. 두 개의 하위 시퀀스를 병합합니다. 최종 정렬 순서로 들어갑니다.

    2. 프로세스 분석

    (1) 이제 분할 용어 [1](0에서 0까지의 인덱스, 양쪽에 포함)과 [28] 1에서 1까지의 인덱스, 양쪽에 포함)을 병합합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (2), 1(왼쪽 분할) <= 28(오른쪽 분할)이므로 {rightPart}를 새 배열에 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (3) 왼쪽 분할이 비어 있으므로 28(오른쪽 분할)을 새 배열에 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (4) 새 배열의 요소를 원래 배열로 다시 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (5), 3(왼쪽 분할) <= 21(오른쪽 분할)이므로 {rightPart}를 새 배열에 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (6) 왼쪽 분할이 비어 있으므로 21(오른쪽 분할)을 새 배열에 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (7) 이제 분할 항목 [1,28](0에서 1까지의 인덱스, 양쪽에 포함)과 [3,21](2에서 3까지의 인덱스, 양쪽에 포함)을 병합합니다. 함께 .

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (8), 1(왼쪽 분할) <= 3(오른쪽 분할)이므로 {rightPart}를 새 배열에 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (9), 28(왼쪽 분할) > 3(오른쪽 분할)이므로 {rightPart}를 새 배열에 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (10), 28(왼쪽 분할) > 21(오른쪽 분할)이므로 {rightPart}를 새 배열에 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (11), 오른쪽 분할이 비어 있으므로 28(왼쪽 분할)을 새 배열에 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (12), 새 배열의 요소를 원래 배열로 다시 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (13), 이제 분할 용어 [11](4에서 4까지의 인덱스, 양쪽 포함)과 [7] 5에서 5까지의 인덱스, 양쪽 모두 포함)를 병합합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (14), 11(왼쪽 분할) > 7(오른쪽 분할)이므로 {rightPart}를 새 배열에 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (15), 오른쪽 분할이 비어 있으므로 11(왼쪽 분할)을 새 배열에 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (16), 새 배열의 요소를 원래 배열로 다시 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (17) 등

    (18)은 1(왼쪽 분할) <= 6(오른쪽 분할)이므로 {rightPart}를 새 배열에 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (19), 3(왼쪽 분할) <= 6(오른쪽 분할)이므로 {rightPart}를 새 배열에 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (20), 21(왼쪽 분할) > 6(오른쪽 분할)이므로 {rightPart}를 새 배열에 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (21), 21(왼쪽 분할) > 7(오른쪽 분할)이므로 {rightPart}를 새 배열에 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    (22) 등을 통해 새 배열의 요소를 원래 배열로 다시 복사합니다.

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    3. GIF 시연

    Java의 병합 정렬 알고리즘의 원리와 구현 방법

    3.알고리즘 구현

    package com.algorithm.tenSortingAlgorithm;
    
    import java.util.Arrays;
    
    public class MergeSort {
        private static void mergeSort(int[] arr, int low, int high) {
            if (low < high) { //当子序列中只有一个元素时结束递归
                int mid = (low + high) / 2; //划分子序列
                mergeSort(arr, low, mid); //对左侧子序列进行递归排序
                mergeSort(arr, mid + 1, high); //对右侧子序列进行递归排序
                merge(arr, low, mid, high); //合并
            }
        }
    
        private static void merge(int[] arr, int low, int mid, int high) {
            int[] temp = new int[arr.length]; //辅助数组
            int k = 0, i = low, j = mid + 1; //i左边序列和j右边序列起始索引,k是存放指针
            while (i <= mid && j <= high) {
                if (arr[i] <= arr[j]) {
                    temp[k++] = arr[i++];
                } else {
                    temp[k++] = arr[j++];
                }
            }
            //如果第一个序列未检测完,直接将后面所有元素加到合并的序列中
            while (i <= mid) {
                temp[k++] = arr[i++];
            }
            //同上
            while (j <= high) {
                temp[k++] = arr[j++];
            }
            //复制回原数组
            for (int t = 0; t < k; t++) {
                arr[low + t] = temp[t];
            }
        }
    
        public static void main(String[] args) {
            int[] arr = {1,28,3,21,11,7,6,18};
            mergeSort(arr, 0, arr.length - 1);
            System.out.println(Arrays.toString(arr));
        }
    }
    로그인 후 복사

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

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