归并排序代码

主程序
int main(int argc, char const *argv[])
{int arr[] = {9,5,2,7};int n= sizeof(arr)/siezof(arr[0]);print_arr(arr,n);//打印数组merge_sort(arr, n);//分类数组print_arr(arr,n);//打印数组return 0;
}
归并排序入口
//归并排序入口
void merge_sort(int arr[], int n)
{//分配辅助数组int *tempArr = (int *)malloc(n* sizeof(int));if(tempArr){msort(arr, tempArr, 0, n-1);free(tempArr);}else{printf("error: failed to allocate memory!");}
}
归并排序
void msort(int arr[], int tempArr[], int left, int right)
{//如果只有一个元素,那么不需要继续划分//只有一个元素的区域,本身就有序,直接归并if(left < right){//找中间点int mid = (left + right)/2;//递归划分左半区msort(arr, tempArr,left, mid);//递归划分右半区msort(arr, tempArr,mid+1, right);//合并已经排序部分merge(arr, tempArr,left, mid, right);}
}
合并

void merge(int arr[], int tempArr[], int left, int mid, int right)
{//标记左半区第一个未排序的元素int l_pos = left;//标记右半区第一个未排序的元素int r_pos = mid + 1;//联合数组元素的下标int pos = left;//合并while(l_pos <= mid && r_pos <= right){if(arr[l_pos] < arr[r_pos])tempArr[pos++] = arr[l_pos++];		//左半区剩余元素更小else tempArr[pos++] = arr[r_pos++];		//右半区剩余元素更小}//合并左半区剩余的元素while(l_pos <= mid){tempArr[pos++] = arr[l_pos++];		//左半区剩余元素更小}//合并右半区剩余的元素while(r_pos <= right){tempArr[pos++] = arr[r_pos++];		//右半区剩余元素更小}//把临时数组中合并后的元素复制回原来的数组while(left <= right){arr[left] = tempArr[left]; left++;}
}
打印
void print_arr(int arr[], int n)
{for(int i =0;i<n; i++){printf("%d ",arr[i]);}
putchar('\n');
}

 整体代码附上

#include <stdio.h>
#include <stdlib.h>void print_arr(int* arr, int n)
{for(int i =0;i<n; i++){printf("%d ",arr[i]);}putchar('\n');
}void merge(int arr[], int tempArr[], int left, int mid, int right)
{//标记左半区第一个未排序的元素int l_pos = left;//标记右半区第一个未排序的元素int r_pos = mid + 1;//联合数组元素的下标int pos = left;//合并while(l_pos <= mid && r_pos <= right){if(arr[l_pos] < arr[r_pos])tempArr[pos++] = arr[l_pos++];		//左半区剩余元素更小else tempArr[pos++] = arr[r_pos++];		//右半区剩余元素更小}//合并左半区剩余的元素while(l_pos <= mid){tempArr[pos++] = arr[l_pos++];		//左半区剩余元素更小}//合并右半区剩余的元素while(r_pos <= right){tempArr[pos++] = arr[r_pos++];		//右半区剩余元素更小}//把临时数组中合并后的元素复制回原来的数组while(left <= right){arr[left] = tempArr[left]; left++;}
}void msort(int arr[], int tempArr[], int left, int right)
{//如果只有一个元素,那么不需要继续划分//只有一个元素的区域,本身就有序,直接归并if(left < right){//找中间点int mid = (left + right)/2;//递归划分左半区msort(arr, tempArr, left, mid);//递归划分右半区msort(arr, tempArr, mid+1, right);//合并已经排序部分merge(arr, tempArr, left, mid, right);}
}//归并排序入口
void merge_sort(int arr[], int n)
{//分配辅助数组int *tempArr = (int *)malloc(n * sizeof(int));if(tempArr){msort(arr, tempArr, 0, n-1);free(tempArr);}else{printf("error: failed to allocate memory!");}
}int main(int argc, char const *argv[])
{int arr[] = {9,5,2,7};int n=sizeof(arr)/sizeof(arr[0]);print_arr(arr,n);//打印数组merge_sort(arr, n);//分类数组print_arr(arr,n);//打印数组return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/32589.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一文带你了解集装箱箱号识别原理,OCR识别及深度学习

如果要想知道集装箱箱号识别原理&#xff0c;首先需要知道什么是集装箱号&#xff08;装运出口货物的集装箱箱号&#xff09;标准集装箱箱号由11位编码组成包括三个部分&#xff1a; 第一部分由4位英文字母组成。前三位代码主要说明箱主、经营人&#xff0c;第四位代码说明集装…

【Oracle】实验二 体系结构、存储结构与各类参数

【实验目的】 理解Oracle体系结构了解初始化参数文件以及初始化参数的含义掌握查看三类数据字典视图和动态性能视图的方法 【实验内容】 如何查看初始化参数&#xff1f;有哪几种方法&#xff1f;初始化参数文件有几种&#xff1f;默认的保存位置在哪里&#xff1f;在SQL*Pl…

【开发】内网穿透ztncui搭建私有节点

文章目录 写在前面一键部署ztnuci记录后续 写在前面 前面搭建moon节点转发的确会降低延迟&#xff0c;但是总有出现moon节点解析不成功的例子&#xff0c;于是疯狂寻找答案是为什么&#xff1f;终于在知乎上找到这样一个答案。 一键部署ztnuci 参考这篇很完善的教程和贴心的…

AI味太重怎么办?1个超简单的方法就能解决

我们知道随着GPT技术的迅速发展&#xff0c;解决了我们大部分写作的难题。但是很多小伙伴想必都会遇到同样的问题&#xff0c;就是写出来的文章太正式-我们叫这“AI味”。 这AI味让人感觉内容虽然条理清楚&#xff0c;但就是缺了点人情味&#xff0c;读起来不够亲切。 其实&a…

基于YOLOv5的口罩佩戴检测系统的设计与实现(PyQT页面+YOLOv5模型+数据集)

简介 在各种工作环境和公共场所,确保人们正确佩戴口罩对个人防护和公共卫生至关重要,尤其是在医疗设施、制造业车间和拥挤的公共交通中。为了满足这一需求,我们开发了一种基于YOLOv5目标检测模型的口罩佩戴检测系统。本项目不仅实现了高精度的口罩佩戴检测,还设计了一个可…

【计算机网络仿真】b站湖科大教书匠思科Packet Tracer——实验6 生成树协议STP的功能

一、实验目的 1.验证以太网交换机生成树协议的功能&#xff1b; 2.理解网络环路对网络的负面效应&#xff1b; 3.理解生成树协议的作用。 二、实验要求 1.使用Cisco Packet Tracer仿真平台&#xff1b; 2.观看B站湖科大教书匠仿真实验视频&#xff0c;完成对应实验。 三、实…

Android assets资源目录

目录 前言一、读取assets下的文件内容二、拷贝assets文件三、AssetManager 前言 Android 中常用的资源分为两种&#xff1a; res下可编译的资源文件assets文件夹下面的原生资源文件 第一种是res下可编译的资源文件&#xff0c;这些资源文件经过编译后会生成一个R.java文件&a…

图解注意力

图解注意力 Part #2: The Illustrated Self-Attention 在文章前面的部分&#xff0c;我们展示了这张图片来展示自注意力被应用于正在处理单词"it"的一层中&#xff1a; 在本节中&#xff0c;我们将看看这是如何完成的。请注意&#xff0c;我们将以一种试图理解单…

华为OD机考(HJ16 购物单)

前言 应广大同学要求&#xff0c;开始以OD机考题作为练习题&#xff0c;看看算法和数据结构掌握情况。有需要练习的可以关注下。此题难度略大&#xff0c;需要对背包问题较为熟悉&#xff0c;同时题干信息量较大&#xff0c;都为解题造成了一定难度。 在开始此题前请提前查看…

网卡故障但bond0不切换原因及处理、脚本监控bond0网卡状态并做相应操作

文章目录 故障说明监控脚本脚本编写脚本测试正常场景异常场景1异常场景2脚本准备和修改网卡名脚本拷贝到所有需要监控主机修改网卡名批量执行脚本故障说明 在一次交换机升级的割接中,主备交换机重启的时候,我们发现了一个问题,有几台宿主机会中断【ping不通】,交换机重启完…

Typora最新安装教程2024

Typora是一款广受好评的跨平台Markdown编辑软件&#xff0c;支持Windows、MacOS和Linux操作系统。它的设计旨在提供一个无干扰、高效且直观的写作环境。户快速管理和查找文档&#xff0c;支持直接在软件内浏览和操作文件结构。 Typora以其简洁而强大的功能集合&#xff0c;成为…

Java模拟马尔可夫链类问题的验证

马尔可夫链&#xff08;Markov Chain, MC&#xff09;是概率论和数理统计中具有马尔可夫性质&#xff08;Markov property&#xff09;且存在于离散的指数集&#xff08;index set&#xff09;和状态空间&#xff08;state space&#xff09;内的随机过程&#xff08;stochasti…

学习笔记——路由网络基础——路由的高级特性

七、路由的高级特性 1、路由迭代(路由递归) 路由必须有直连的下一跳才能够指导转发&#xff0c;静态路由或BGP路由的下一跳可能不是直连的邻居&#xff0c;因此需要计算出一个直连的下一跳和对应的出接口&#xff0c;这个过程就叫做路由迭代(路由递归)。 添加一条去往20.1.1.…

JAVA期末复习2

目录 一、Java基础知识 1. 下面几个标识符中&#xff0c;哪些是命名正确的 (A) 2. 分析以下代码&#xff0c;哪些是合法的 (C) 3. 以下代码的执行结果是&#xff08; B &#xff09; 4. 下面哪个不是java中的关键字&#xff1f;&#xff08; B &#xff09; 5. 下面对数组…

毕业设计——可视化实验仿真平台

该程序用于毕业设计&#xff0c;架构为前后端分离技术&#xff0c;涉及技术包括vue3&#xff0c;SpringBoot&#xff0c;spring-secrity&#xff0c;Redis&#xff0c;需要者进群769119544进行相关咨询。 程序分为三个角色&#xff1a;学生、老师、管理员。使用了spring-secrit…

如何在 Android 应用中设置 `android:authorities`

在 Android 应用中设置 android:authorities 属性主要是为 ContentProvider 或 FileProvider 定义的&#xff0c;以确保这些提供者可以在应用之间或应用内部被唯一地识别。以下是如何为 FileProvider 设置 android:authorities 的步骤&#xff1a; 定义 FileProvider&#xff1…

字节豆包全新图像Tokenizer:生成图像最低只需32个token,最高提速410倍

ChatGPT狂飙160天&#xff0c;世界已经不是之前的样子。 更多资源欢迎关注 在生成式模型的迅速发展中&#xff0c;Image Tokenization 扮演着一个很重要的角色&#xff0c;例如Diffusion依赖的VAE或者是Transformer依赖的VQGAN。这些Tokenizers会将图像编码至一个更为紧凑的隐…

Redis 学习笔记(2)

目录 1 Redis的持久化1.1 RDB持久化方案1.2 AOF持久化方案 2 Redis架构2.1 主从复制架构2.2 哨兵集群设计2.3 哨兵集群设计 3 Redis事务机制4 Redis过期策略与内存淘汰机制4.1 过期策略4.2 内存淘汰机制 5 Redis高频面试题4.1 缓存穿透4.2 缓存击穿4.3 缓存雪崩 1 Redis的持久化…

C++中的文件操作

1、文件操作 文章目录 1、文件操作1.读写TXT文件1.写文件2.读文件3.读文件的方式4.注意事项 2.读写二进制文件1.写入二进制文件2.读取二进制文件3.注意事项 1.读写TXT文件 在C中&#xff0c;读取和写入文件通常涉及到使用<fstream>库中的类&#xff0c;主要是ifstream&a…

C++STL 初阶(5)vector的简易实现(上)

不同于string只实现一个最简单的版本&#xff0c;vector在此处我们要实现的是模版类&#xff0c;类模版的声明和定义分离非常不方便&#xff08;会在链接时报错&#xff09;&#xff0c;所以我们都只在一个vector.h下去实现声明和定义。后续我们提及到的库里面实现的vector也是…