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

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

PHPz
PHPz앞으로
2023-04-19 17:43:16847검색

    1. 기본 개념

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

    2. 알고리즘 분석

    1. 알고리즘 설명

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

    2. 프로세스 분석

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

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

    (2), 1(왼쪽 분할) 90d40e005e0c1364b9ad0f3285ca99b1 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(왼쪽 분할) fc68618b7a4b4d2a93f117ce999ae67e 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으로 문의하시기 바랍니다. 삭제