归并排序算法

想实现一个数组A[]的排序,可以将数组分成两个数组分别排序,有序的两个数组再按一定规则合成一个数组,很容易想到,最终的结果就是得到两个只含一个数字的数组,一定是有序的,那么通过递归,层层回推,得到有序的A[]。

算法的实现需要2个函数:

void MERGE(int* A, int p, int q, int r){
    //calculate the largest int  
    unsigned int a = 0;  
    int MAX = (~a)/2;  
    //create 2 new arrays  
    int L[100];  
    int K[100];  
    int i, j, temp;  
    for(i = 0; i < q-p+1; i++) {
        L[i] = A[p+i];  
    }
    L[i] = MAX;  
    for(i = 0; i < r-q; i++) {
       K[i] = A[q+i+1];  
    }  
    K[i] = MAX;  
    i = 0;  
    j = 0;  
    for(temp = p; temp <= r; temp++) {
        if (L[i] < K[j]) {
            A[temp] = L[i];  
            i++;  
        } else {
            A[temp] = K[j];  
            j++;
        }
    }
}

void MERGESORT(int* A, int p, int r){  
    if (p < r) {
        int q = (p+r)/2;  
        MERGESORT(A, p, q);  
        MERGESORT(A, q+1, r);  
        MERGE(A, p, q, r);  
    }
}

在main函数中通过调用MERGESORT就可以实现数组的由小到大的排序了。

int main () {  
    int a[4];  
    a[0] = 10;  
    a[1] = 5;  
    a[2] = 6;  
    a[3] = 4;  
    MERGESORT(a, 0, 3);  
    cout << a[0] << endl;  
    cout << a[1] << endl;  
    cout << a[2] << endl;  
    cout << a[3] << endl;  
    return 0;  
}

以上运行的结果:




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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值