双调排序程序解析(可对任意长度的序列排序)

本文深入解析双调排序程序,通过与归并排序的对比,帮助理解双调排序中不按原二分界限归并的过程。双调排序在归并时以2的幂次方为界限,确保最终得到升序序列。以6个元素为例,前3个降序,后3个升序,然后以4为界限进行比较,最终完成排序。
摘要由CSDN通过智能技术生成

上一篇文章中给出了可对任意长度的序列进行排序的双调排序的程序实现,这篇文章将对程序进行解析,通过与归并排序的对比有助于对程序的理解。

首先回顾一下归并排序的程序实现:

public class MergeSorter
{
    private int[] a;
    private final static boolean ASCENDING=true;    // sorting direction

    public void sort(int[] a)
    {
        this.a=a;
        mergeSort(0, a.length, ASCENDING);
    }

    private void mergeSort(int lo, int n, boolean dir)
    {
        if (n>1)
        {
            int m=n/2;
            mergeSort(lo, m, dir);
            mergeSort(lo+m, n-m, dir);
            merge(lo, n, dir);
        }
    }

    private void merge(int lo, int n, boolean dir)
    {
        if (n>1)
        {
        	  int m=n/2;
        	  
        	  for (int i=lo; i<lo+m; i++)
        	  {
        	  	  if (dir==(a[i]>a[lo+m]))
        	  	  {
        	  	  	  exchange(i,lo+m);
        	  	  	  
        	  	  	  int k=lo+m;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值