效率最高的归并排序(c语言)



#include "stdafx.h"
#include "mergeSort.h"

void merge(int* pSource, int l1, int r1, int l2, int r2, int* pTarget);
void mergeRecursion(int* pSource, int l, int r, int* pTarget);

void mergeSort(int* pSource, int len)
{
 int* pTarget = new int[len];
 memcpy(pTarget, pSource, len*sizeof(int));

 mergeRecursion(pTarget, 0, len - 1, pSource);

 delete[]pTarget;
}

void mergeRecursion(int* pSource, int l, int r, int* pTarget)
{
 int lA, rA, lB, rB;

 if (l != r)
 {
  lA = l;
  rA = (l + r) / 2;
  lB = rA + 1;
  rB = r;

  mergeRecursion(pTarget, lA, rA, pSource);
  mergeRecursion(pTarget, lB, rB, pSource);
  merge(pSource, lA, rA, lB, rB, pTarget);
 }
}

void merge(int* pSource, int l1, int r1, int l2, int r2, int* pTarget)
{
 int a = l1, b = l2, i = l1;
 int x = pSource[r1] > pSource[r2] ? pSource[r2] : pSource[r1];
 while (true)
 {
  if (pSource[a] <= pSource[b])
  {
   pTarget[i] = pSource[a];
   a++;
  }
  else
  {
   pTarget[i] = pSource[b];
   b++;
  }
  if (pTarget[i] == x)
  {
   i++;
   break;
  }
  i++;
 }
 if (a > r1)
 {
  while (b <= r2){
   pTarget[i] = pSource[b];
   b++;
   i++;
  }
 }
 else{
  while (a <= r1){
   pTarget[i] = pSource[a];
   a++;
   i++;
  }
 }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值