归并排序算法的C++实现

归并排序是一种常用的排序算法,其原理是将每一个数看作一个有序序列,然后不断地将两个相邻的有序序列合并成一个有序序列,最后剩下一个有序序列就是排序后的结果。用到的是递归和分治思想。

#include<iostream>
#include<malloc.h>
using namespace std;

void merge(int arr[], int tempArr[], int left, int mid, int right){
    int l_pos = left;   //左半区第一个未排序的元素位置
    int r_pos = mid+1;  //右半区第一个未排序的元素位置
    int pos = left;     //存入临时数组时的元素位置

    //进行归并排序的合并操作
    while(l_pos<=mid && r_pos<=right){
        if(arr[l_pos] < arr[r_pos]){
            tempArr[pos++] = arr[l_pos++];
        }else{
            tempArr[pos++] = arr[r_pos++];
        }
    }

    //左半区有剩余元素
    while(l_pos <= mid){
        tempArr[pos++] = arr[l_pos++];
    }

    //右半区有剩余元素
    while(r_pos <= right){
        tempArr[pos++] = arr[r_pos++];
    }

    //把合并好的临时数组复制回原始数组
    pos = left;
    while(pos <= right){
        arr[pos] = tempArr[pos];
        pos++;
    }
}

void msort(int arr[], int tempArr[], int left, int right){
    
    if(left < right){ // 有两个及以上的元素时进行划分
        int mid = (right + left) / 2;   // 找到中间的位置

        msort(arr, tempArr, left, mid); // 递归划分arr数组的左半部分

        msort(arr, tempArr, mid+1, right);  // 递归划分arr数组的右半部分

        merge(arr, tempArr, left, mid, right);  // 合并已经排序的部分

    }
}

// 归并排序入口
void MergeSort(int arr[], int n){
    // 进行归并排序的原始数组arr, 数组长度n

    // 申请相同长度的临时数组空间
    int *tempArr = (int*)malloc(n * sizeof(int));
    if(tempArr){
        cout << "Allocate Memory successfully" << endl;
        msort(arr, tempArr, 0, n-1);
        for(int i=0; i<n; i++){
            cout << *(tempArr+i) << " ";
        }
        free(tempArr);
    }else{
        cout << "error: failed to allocate memory!" << endl;
    }
}

int main(){
    int arr[9] = {3, 56, 32, 11, 14, 20, 39, 45, 109};
    MergeSort(arr, 9);

    return 0;
}
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

晚风也很浪漫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值