归并排序

归并排序

         归并排序是利归并的思想实现的排序算法,即采用经典的分治策略。

归并排序的示意图1   基本思想

归并排序的示意图2  合并有序子序列

       上图中最后一次合并是将[4,5,7,8]以及[1,2,3,6]合并为[1,2,3,4,5,6,7,8]图示结果如下

分解和合并代码如下

将两个有序子序列合并
 public static void merge(int[] arr,int left,int mid,int right,int[] temp){
        int i=left;//左边数组初始索引
        int j=mid+1;//右边数组初始索引
        int t=0;
        //有序数组转移到temp,直到左右两边有一边数组完成转移
        while (i<=mid&&j<=right){
            if(arr[i]<arr[j]){
                temp[t]=arr[i];
                t++;
                i++;
            }else {
                temp[t]=arr[j];
                t++;
                j++;
            }
        }
        //剩余的转移到temp
        //如果左边数组有剩余,则继续进行转移
        while (i<=mid){
            temp[t]=arr[i];
            t++;
            i++;
        }
        //如果右边数组有剩余,则继续进行转移
        while (j<=right){
            temp[t]=arr[j];
            t++;
            j++;
        }
        //temp数组转移到arr;
        t=0;
        while (left<=right){
            arr[left]=temp[t];
            t++;
            left++;
        }

    }
采用递归的方法对数组进行分解

public static void mergesort(int[] arr,int left,int right,int[] temp){
        if(left>=right){
            return;
        }
        int mid=left+(right-left)/2;
        //向左递归进行分解
        mergesort(arr,left,mid,temp);
        //向右递归进行分解
        mergesort(arr,mid+1,right,temp);
        //合并两个有序数组
        merge(arr,left,mid,right,temp);

    }

完整代码如下

import java.util.Arrays;

public class MergeSort {
    public static void main(String[] args) {
        int[] arr={8,4,5,7,1,3,6,2,10,-1,2000,10,7,8};
        int[] temp=new int[arr.length];
        mergesort(arr,0,arr.length-1,temp);
        System.out.println(Arrays.toString(arr));

    }
    //分解+合并
    public static void mergesort(int[] arr,int left,int right,int[] temp){
        if(left>=right){
            return;
        }
        int mid=left+(right-left)/2;
        //向左递归进行分解
        mergesort(arr,left,mid,temp);
        //向右递归进行分解
        mergesort(arr,mid+1,right,temp);
        //合并两个有序数组
        merge(arr,left,mid,right,temp);

    }
    public static void merge(int[] arr,int left,int mid,int right,int[] temp){
        int i=left;//左边数组初始索引
        int j=mid+1;//右边数组初始索引
        int t=0;
        //有序数组转移到temp,直到左右两边有一边数组完成转移
        while (i<=mid&&j<=right){
            if(arr[i]<arr[j]){
                temp[t]=arr[i];
                t++;
                i++;
            }else {
                temp[t]=arr[j];
                t++;
                j++;
            }
        }
        //剩余的转移到temp
        //如果左边数组有剩余,则继续进行转移
        while (i<=mid){
            temp[t]=arr[i];
            t++;
            i++;
        }
        //如果右边数组有剩余,则继续进行转移
        while (j<=right){
            temp[t]=arr[j];
            t++;
            j++;
        }
        //temp数组转移到arr;
        t=0;
        while (left<=right){
            arr[left]=temp[t];
            t++;
            left++;
        }

    }
}



#堆排序小根堆#
全部评论
似乎学习到了
点赞 回复 分享
发布于 2022-10-08 12:07 陕西

相关推荐

预计下个星期就能开奖吧,哪位老哥来给个准信
华孝子爱信等:对接人上周说的是这周
点赞 评论 收藏
分享
牛客868257804号:九个中铁八个中建
点赞 评论 收藏
分享
1 3 评论
分享
牛客网
牛客企业服务