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

#include <stdio.h>

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

int i;

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

{

a[i+left] = b[i];

}

}

// 将 a[left,middle] 和 a[middle+1,right]合并到 b[left, right]中

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

int b[right-left+1];

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

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

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

int q; // 循环变量

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

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

if(a[i]<=a[j]){

b[k] = a[i];

i++;

}else{

b[k] = a[j];

j++;

}

k++;

}

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

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

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

b[k] = a[q];

k++;

}

}else{ // 将 a[1,middle]中剩余部分拷贝到 b 数组当中

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

b[k] = a[q];

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); // 对 a[left,middle] 进行合并排序

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

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

}

}

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

int arrayLength,i;

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

scanf("%d",&arrayLength);

int a[arrayLength];

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

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

scanf("%d",&a[i]);

}

MergeSort(a, 0, arrayLength-1);

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

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

printf("%d ",a[i]);

}

return 0;

}

相关推荐
雾月552 分钟前
LeetCode 1292 元素和小于等于阈值的正方形的最大边长
java·数据结构·算法·leetcode·职场和发展
知来者逆2 小时前
计算机视觉——速度与精度的完美结合的实时目标检测算法RF-DETR详解
图像处理·人工智能·深度学习·算法·目标检测·计算机视觉·rf-detr
阿让啊2 小时前
C语言中操作字节的某一位
c语言·开发语言·数据结构·单片机·算法
এ᭄画画的北北2 小时前
力扣-160.相交链表
算法·leetcode·链表
爱研究的小陈3 小时前
Day 3:数学基础回顾——线性代数与概率论在AI中的核心作用
算法
渭雨轻尘_学习计算机ing3 小时前
二叉树的最大宽度计算
算法·面试
BB_CC_DD3 小时前
四. 以Annoy算法建树的方式聚类清洗图像数据集,一次建树,无限次聚类搜索,提升聚类搜索效率。(附完整代码)
深度学习·算法·聚类
梁下轻语的秋缘5 小时前
每日c/c++题 备战蓝桥杯 ([洛谷 P1226] 快速幂求模题解)
c++·算法·蓝桥杯
CODE_RabbitV5 小时前
【深度强化学习 DRL 快速实践】逆向强化学习算法 (IRL)
算法
mit6.8245 小时前
[贪心_7] 最优除法 | 跳跃游戏 II | 加油站
数据结构·算法·leetcode