ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

归并排序算法代码实现

2022-07-16 08:33:10  阅读:132  来源: 互联网

标签:归并 right temp int arr mid 算法 排序 left


上代码

package com.liu.pro;

import java.util.Arrays;

public class mergeSort {
    public static void main(String[] args) {
//      测试数组
        int[] arr = {9, 8, 5, 6, 2, 7, 1, 3, 4};
        int[] temp = new int[arr.length];
        sort(arr, 0, arr.length - 1, temp);
        System.out.println("归并排序算法");
        System.out.println(Arrays.toString(arr));
    }

    public static void sort(int[] arr, int left, int right, int[] temp) {

        if (left < right) {
//          找到中间值mid索引
            int mid = (left + right) / 2;
//          调用方法向左进行递归分解
            sort(arr, left, mid, temp);
//          调用方法向右进行递归分解,mid+1为了让递归的元素不重复
            sort(arr, mid + 1, right, temp);
//          递归合并
            mergeSort(arr, left, mid, right, temp);
        }
    }

    /**
     * 归并排序中的"合"实现
     *
     * @param arr   即将排序的数组
     * @param left  左边界索引
     * @param mid   中间值
     * @param right 右边界索引
     * @param temp  临时的数组
     */
    public static void mergeSort(int[] arr, int left, int mid, int right, int[] temp) {
//      定义一个左索引变量
        int i = left;
//      定义一个右索引变量
        int j = mid + 1;
//      定义临时temp数组的下标索引t,放入temp数组进行中转,递归
        int t = 0;
//      左右两边只要有一个将数全部放入temp中,则退出循环,否则一直循环查找
        while (i <= mid && j <= right) {
//          如果左边的比右边的数小,就将左边的数放入temp
//          反之(相等或者大于)则将右边的数放入temp
            if (arr[i] < arr[j]) {
                temp[t] = arr[i];
//              索引后移
                i += 1;
                t += 1;
            } else {
                temp[t] = arr[j];
//              同上
                j += 1;
                t += 1;
            }
        }
//      上述循环结束有二种情况1.左侧数组全部放入temp 2.右侧数组全部放入temp
//      左侧数组没有全部放入,则将其放入temp
        while (i <= mid) {
            temp[t] = arr[i];
            i += 1;
            t += 1;
        }
//      右侧数组没有完全放入,则将右侧数组完全放入temp
        while (j <= right) {
            temp[t] = arr[j];
            j += 1;
            t += 1;
        }
//      将排好顺序的temp放入arr[]数组将数组中的数值进行更新,再进行后续递归调用
//      重置temp下标
        t = 0;
//      重新定义一个指针
        int tempLeft = left;
//      只要循环中指针tempLeft小于等于right指针,则放入临时数组
//      如果数组已经完全放入
        while (tempLeft <= right) {
            arr[tempLeft] = temp[t];
            tempLeft += 1;
            t += 1;
        }
    }
}

测试结果:

 

标签:归并,right,temp,int,arr,mid,算法,排序,left
来源: https://www.cnblogs.com/lhr123/p/16483304.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有