合并排序算法(C语言版)

#include <stdio.h>

void Copy(int *a, int *b, int left, int right) {

int i;

for(i=0;i<right-left+1;i++)

{

ai+left = bi;

}

}

// 将 aleft,middle 和 amiddle+1,right合并到 bleft, right

void Merge(int *a, int left, int middle, int right) {

int bright-left+1;

int i = left; // left 到 middle 这一段的起始位置

int j = middle + 1; // middle+1 到 right 这一段的起始位置

int k = 0; // 保存到 b 数组中的对应位置索引

int q; // 循环变量

// 当 a1,middle 和 amiddle+1,right 中都有元素时,小的保存到 b 数组中

while((i<=middle)&&(j<=right)){

if(ai<=aj){

bk = ai;

i++;

}else{

bk = aj;

j++;

}

k++;

}

// 把余下部分加入到数组中

if(i>middle){ // 将 amiddle+1,right中剩余部分拷贝到 b 数组当中

for(q=j; q<=right; q++){

bk = aq;

k++;

}

}else{ // 将 a1,middle中剩余部分拷贝到 b 数组当中

for(q=i; q<=middle; q++){

bk = aq;

k++;

}

}

Copy(a, b, left, right); // 复制回数组 a

}

// 递归写法

void MergeSort(int *a, int left, int right){

int middle;

if(left < right){ // 当至少有两个元素时

middle = (left + right)/2; // 取中点

MergeSort(a, left, middle); // 对 aleft,middle 进行合并排序

MergeSort(a, middle+1, right); // 对 amiddle+1,right 进行合并排序

Merge(a, left, middle, right); // 合并到数组 a

}

}

int main() { //定义 main()主函数

int arrayLength,i;

printf("请输入要合并排序的数组大小:(数组最大上限100)\n");

scanf("%d",&arrayLength);

int aarrayLength;

printf("请输入待排序序列:\n");

for(i=0; i<arrayLength; i++){ //a控制数组大小

scanf("%d",&ai);

}

MergeSort(a, 0, arrayLength-1);

printf("合并排序后的数组为:\n");

for( i=0; i<arrayLength; i++){

printf("%d ",ai);

}

return 0;

}

相关推荐
大白话_NOI15 分钟前
【洛谷 P2249】查找(深基 13. 例 1)+ 详细分析
c++·算法
吠品15 分钟前
C++实现m行n列带边框的长方形输出
算法
智者知已应修善业23 分钟前
【51单片机2个外部中断显示中断历时,初始化8左移3位共阳数码管】2024-6-6
c++·经验分享·笔记·算法·51单片机
西安邮电大学1 小时前
分治算法详细讲解
java·后端·其他·算法·面试
code bean1 小时前
平衡相关性与多样性:推荐系统中的永恒博弈与 MMR 算法详解
算法
青梅橘子皮1 小时前
Linux---进程控制(2)(进程程序替换)
linux·c++·算法
Shan12051 小时前
经典问题——验证栈序列
数据结构·算法
2501_906565121 小时前
勾股定理证明
算法
Shan12052 小时前
无向图的Hierholzer算法流程(二)
算法
gihigo19982 小时前
基于蒙特卡洛的异常值剔除(RANSAC + MC置信区间)—MATLAB实现
开发语言·算法·matlab