java归并排序算法案例_java实现归并排序算法

归并排序就是将未排序的数组进行对半划分成两个数组,划分后的数组只有原来数组的一半数量的元素。然后在对划分的两个数组再继续划分,循环此操作,直到划分的数组中只有一个元素时停止划分,然后对于划分完成的数组进行归并排序操作。将两个已经划分完成的数组合并成一个有序的数组,直到最后合并成一个包含所有元素的数组,合并排序操作完成。下面以图形来演示下归并排序的过程。

假设有一个未排序数组:{3,2,4,1},下面为数组的划分过程,先将数组对半划分为{3,2}和{4,1}两个数组。然后在对这两个数组进行划分最后得到{3},{2},{4},{1}四个数组,划分完成。

e0d6e209de9ea3ef2c85e8ee28401ccc.png

接下来对数组进行归并,先将{3}和{2}这两个数组合并成一个有序的数组{2,3},同理对4,1进行相同的操作,得到{1,4},然后在将合并好的这两个有序数组进行合并,最后合并成{1,2,3,4},归并完成。

bcac9ebebd8458f4b75de35c5875fae3.png

归并排序算法用java代码实现如下:

public static void MergeSort(int[] array,int head,int tail){

// 判断数组的头部索引是否小于尾部索引

if(head < tail){

int middle = (head+tail)/2;

MergeSort(array,head,middle);

MergeSort(array,middle+1,tail);

Merge(array,head,middle,tail);

}

}

public static void Merge(int[] array, int head, int middle, int tail) {

// TODO Auto-generated method stub

int[] temp = new int[tail - head + 1];

int a = head;

int b = middle + 1;

int i = 0;

// 对于两个数组中的数进行比较,将较小的值存放在临时数组中

while(a <= middle && b <=tail){

if(array[a] < array[b]){

temp[i++] = array[a++];

}

else{

temp[i++] = array[b++];

}

}

// 将未参与比较的数组中的数添加到临时数组中

while(a <= middle){

temp[i++] = array[a++];

}

while(b <= tail){

temp[i++] = array[b++];

}

// 将排好序的数组放回到array数组中

System.arraycopy(temp,0,array,head,tail - head + 1);

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值