3、实现典型的归并排序的分治算法的编程与上机实验,验证算法的时间复杂性函数。

public class Allpaixu {
static int number=0;
public static void main(String[] args) {
int[] a = {26, 5, 98, 108, 28, 99, 100, 56, 34, 1 };
printArray(“排序前:”,a);
MergeSort(a);
printArray(“排序后:”,a);
}

private static void printArray(String pre,int[] a) {
    System.out.print(pre+"\n");
    for(int i=0;i<a.length;i++)
        System.out.print(a[i]+"\t");    
    System.out.println();
}

private static void MergeSort(int[] a) {
    // TODO Auto-generated method stub
    System.out.println("开始排序");
    Sort(a, 0, a.length - 1);
}

private static void Sort(int[] a, int left, int right) {
    if(left==right)   //递归结束的标志
        return;

    int mid = (left + right) / 2;
    //二路归并排序里面有两个Sort,多路归并排序里面写多个Sort就可以了
    Sort(a, left, mid);
    Sort(a, mid + 1, right);
    merge(a, left, mid, right);

}


private static void merge(int[] a, int left, int mid, int right) {

    int[] tmp = new int[a.length];
    int r1 = mid + 1;
    int tIndex = left;
    int cIndex=left;
    // 逐个归并
    while(left <=mid && r1 <= right) {
        if (a[left] <= a[r1])        //第一次a[0]和a[1]比较,
            tmp[tIndex++] = a[left++];  
        else
            tmp[tIndex++] = a[r1++];  //第一次先填充a[1]给tmp[0]
    }
        // 将左边剩余的归并
        while (left <=mid) {
            tmp[tIndex++] = a[left++];   //第一次将剩余的a[0]给tmp[1]
        }
        // 将右边剩余的归并
        while ( r1 <= right ) {
            tmp[tIndex++] = a[r1++];
        }       
        System.out.println("第"+(++number)+"趟排序:\t");
        // TODO Auto-generated method stub
        //从临时数组拷贝到原数组
         while(cIndex<=right){
                a[cIndex]=tmp[cIndex];
                //输出中间归并排序结果
                System.out.print(a[cIndex]+"\t");
                cIndex++;
            }
         System.out.println();
    }
}

在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值