当前位置: 首页 > news >正文

合并排序算法(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;
}
 

http://www.lryc.cn/news/472170.html

相关文章:

  • C++——输入一行文字,找出其中的大写字母、小写字母、空格数字以及其他字符各有多少。用指针或引用方法处理。
  • 【skywalking】maximum query complexity exceeded 3336 > 3000
  • 开源一个开发的聊天应用与AI开发框架,集成 ChatGPT,支持私有部署的源码
  • 开发了一个成人学位英语助考微信小程序
  • LeetCode16:最接近的三数之和
  • VisualStudio2022配置2D图形库SFML
  • 「Mac畅玩鸿蒙与硬件4」鸿蒙开发环境配置篇4 - DevEco Studio 高效使用技巧
  • 构建生产级的 RAG 系统
  • 完全透彻了解一个asp.net core MVC项目模板2
  • uniapp 如何调用音频
  • 在Facebook运营中使用住宅IP的重要性
  • EJB项目如何升级SpringCloud
  • HTTPS 协议原理
  • Vxe UI 表格行编辑(默认不显示编辑框,点击后可编辑)
  • 移远通信闪耀2024香港秋灯展,以丰富的Matter产品及方案推动智能家居产业发展
  • 爬虫利器playwright
  • 着色器的认识
  • 科技的成就(六十四)
  • 银行信贷风控专题:Python、R 语言机器学习数据挖掘应用实例合集:xgboost、决策树、随机森林、贝叶斯等...
  • 〈壮志凌云:独行侠〉中的超高音速战机
  • k8s集群 ceph rbd 存储动态扩容
  • C语言笔记(指针题目)例题+图解
  • 从零开始的 vue项目部署到服务器详细步骤(vue项目build打包+nginx部署+配置ssl证书)
  • [OceanBase-不止于记录]:揭秘双引擎战略,共探AI时代数据架构未来
  • 项目:抽奖系统
  • synchronized进阶原理
  • C++,STL 052(24.10.29)
  • git下载和配置
  • Linux基础—基础命令及相关知识5(ubuntu网络配置)
  • 使用 firewall-cmd 管理 Linux 防火墙