归并排序算法

归并排序采用分治的思想,现将数组分裂成更小的单元,将小单元的先进性排序,然后逐次合并,启时间复杂度nlogn,由于需要另加一个辅助数组空间复杂度为O(n)

1、分裂

cpp 复制代码
/**
 * 分裂操作
 */
void  merge_sort(int* arr,int left, int right){
  if (left >= right)
    return;
  
  int mid = (left + right) / 2;
  // 分裂操作
  merge_sort(arr, left, mid);
  merge_sort(arr, mid + 1, right);
  // 合并操作
  int* temp = (int*) malloc((right-left)* sizeof(int));
  merge(arr,temp,left,mid,right);
  free(temp);
}

2、合并

cpp 复制代码
/**
 * 合并操作
 */

void merge(int *arr,int* temp,  int left, int mid, int right){
  printf("合并索引: left=%d,mid=%d,right=%d\n", left, mid, right);
  int i = left;
  int j = mid + 1;
  int k = 0;
  // 合并两个有序数组到temp数组中
  while (i <= mid && j <= right) {
    if (arr[i] <= arr[j]) {
      temp[k++] = arr[i++];
    } else {
      temp[k++] = arr[j++];
    }
  }
  // 把左边剩余元素填充进temp数组中

  for (; i <= mid; i++) {
    temp[k++] = arr[i];
  }
  // 把右边剩余元素填充进temp数组中
  for (; j <= right; j++) {
    temp[k++] = arr[j];
  }
// 把temp数组中的元素拷贝回原数组中

  k = 0;
  int tempLeft = left;
  while (tempLeft <= right) {
    arr[tempLeft++] = temp[k++];
  }
}

3、测试

cpp 复制代码
    int arr[] = {11,15,3,5,9,80,90,73,50,66};
    int len = sizeof(arr)/sizeof(arr[0]);
    merge_sort(arr, 0, len-1);
相关推荐
地平线开发者2 小时前
ReID/OSNet 算法模型量化转换实践
算法·自动驾驶
地平线开发者2 小时前
开发者说|EmbodiedGen:为具身智能打造可交互3D世界生成引擎
算法·自动驾驶
星星火柴9363 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
艾莉丝努力练剑4 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
闪电麦坤955 小时前
数据结构:迭代方法(Iteration)实现树的遍历
数据结构·二叉树·
C++、Java和Python的菜鸟6 小时前
第六章 统计初步
算法·机器学习·概率论
Cx330❀6 小时前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
散1126 小时前
01数据结构-Prim算法
数据结构·算法·图论
起个昵称吧6 小时前
线程相关编程、线程间通信、互斥锁
linux·算法
..过云雨7 小时前
01.【数据结构-C语言】数据结构概念&算法效率(时间复杂度和空间复杂度)
c语言·数据结构·笔记·学习