归并排序,递归法,C语言实现。
利用归并排序法对序列排序的示意图(递归法):

一、算法分析:利用递归的分治方法:1、将原序列细分,直到成为单个元素;2、在将分割后的序列一层一层地按顺序合并,完成排序。细分通过不断深入递归完成,合并通过递归 一层层返回完成。
二、C语言代码
1、完成排序的三个函数
void MergeSort(int l[],int lenght)
{
int tmp[lenght]; MSort(l,tmp,,lenght);
} /*分:MSort将原来的序列不断细分,直到为1,再由Merge归并*/
void MSort(int l[],int tmp[],int left,int right)
{
int mid; if(left!=right)
{
mid=(left+right)/; //将待排序序列分成两部分
MSort(l,tmp,left,mid); //将左边排序
MSort(l,tmp,mid+,right); //将右边排序
Merge(l,tmp,left,mid,right); //将已排序的两部分合并
}
} /*数组tmp只是作为临时存储,归并后,再将有序的数组拷贝到原来的l中*/
void Merge(int l[],int tmp[],int left,int mid,int right)
{
int i,j,t; for(i=left,j=mid+,t=left;i<=mid&&j<=right;t++)
{
if(l[i]<=l[j])
{
tmp[t]=l[i];
i++;
}
else
{
tmp[t]=l[j];
j++;
}
}
/*归并的两个序列不一样长时,将剩余的元素加入tmp*/
if(i<=mid)
{
for(;i<=mid;i++)
{
tmp[t]=l[i];
t++;
}
}
if(j<=right)
{
for(;j<=right;j++)
{
tmp[t]=l[j];
t++;
}
}
/*将归并后的有序序列拷贝到原数组*/
for(t=left;t<=right;t++)
{
l[t]=tmp[t];
}
}
使用时,调用MergeSort函数就行了
下面是我写的一个测试代码
#include<stdio.h>
#include<stdlib.h>
#include<time.h> #define NUM 5000 void MergeSort(int l[],int length);
void MSort(int l[],int tmp[],int left,int right);
void Merge(int l[],int tmp[],int left,int mid,int right); int main()
{
int i,a[NUM+]; srand((unsigned)time(NULL));
/*a[0]作为哨兵单元,不在随机数生成之列*/
for(i=;i<=NUM;i++)
{
a[i]=rand();
}
/*printf("Befor sort:");
for(i=1;i<=NUM;i++)
{
printf("%d ",a[i]);
}*/ MergeSort(a,NUM); printf("\nAfter sort:");
for(i=;i<=NUM;i++)
{
printf("%d ",a[i]);
} return ;
} void MergeSort(int l[],int lenght)
{
int tmp[lenght]; MSort(l,tmp,,lenght);
} /*分:MSort将原来的序列不断细分,直到为1,再由Merge归并*/
void MSort(int l[],int tmp[],int left,int right)
{
int mid; if(left!=right)
{
mid=(left+right)/; //将待排序序列分成两部分
MSort(l,tmp,left,mid); //将左边排序
MSort(l,tmp,mid+,right); //将右边排序
Merge(l,tmp,left,mid,right); //将已排序的两部分合并
}
} /*数组tmp只是作为临时存储,归并后,再将有序的数组拷贝到原来的l中*/
void Merge(int l[],int tmp[],int left,int mid,int right)
{
int i,j,t; for(i=left,j=mid+,t=left;i<=mid&&j<=right;t++)
{
if(l[i]<=l[j])
{
tmp[t]=l[i];
i++;
}
else
{
tmp[t]=l[j];
j++;
}
}
/*归并的两个序列不一样长时,将剩余的元素加入tmp*/
if(i<=mid)
{
for(;i<=mid;i++)
{
tmp[t]=l[i];
t++;
}
}
if(j<=right)
{
for(;j<=right;j++)
{
tmp[t]=l[j];
t++;
}
}
/*将归并后的有序序列拷贝到原数组*/
for(t=left;t<=right;t++)
{
l[t]=tmp[t];
}
}
归并排序,递归法,C语言实现。的更多相关文章
- 八皇后问题详细分析与解答(递归法解答,c#语言描述)
八皇后问题,是一个古老而著名的问题,是回溯算法的典型例题.该问题是十九世纪著名的数学家高斯1850年提出:在8X8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行.同一列或 ...
- C语言之函数调用17—递归法之中的一个般函数的调用(2)
//递归法 /* ================================================================== 题目:求F(60),当中F(n)定义例如以下: ...
- C语言之函数调用11—递归法求Hermite函数
/*递归法! ========================================== 题目: Hermite 函数:输入n.x,求Hn(x)? H0(x)=1; H1(x)=2*x; H ...
- 算法笔记_013:汉诺塔问题(Java递归法和非递归法)
目录 1 问题描述 2 解决方案 2.1 递归法 2.2 非递归法 1 问题描述 Simulate the movement of the Towers of Hanoi Puzzle; Bonus ...
- 递归法绑定文件夹到导航树&在指定文件夹下新建文件夹
protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { if (Request.QueryString[&q ...
- PHP利用递归法获取多级类别的树状数组
数据结构:category(id, pid, name),对应:信息ID,父项ID,类别名 测试数据: $aryCate = array( array('id' => 1, 'pid' => ...
- 回溯法 leetcode题解 Combination Sum 递归法
题目大意:给出一个数组,用这些数组里的元素去凑一个target.元素可以重复取用. 感觉对这种题目还是生疏的.脑子里有想法,但是不知道怎么表达出来. 先记录下自己的递归法.应该还可以用循环实现. 回溯 ...
- 用递归法计算从n个人中选选k个人组成一个委员会的不同组合数
用递归法计算从n个人中选选k个人组成一个委员会的不同组合数. 分析 由n个人里选k个人的组合数= 由n-1个人里选k个人的组合数+由n-1个人里选k-1个人的组合数: 当n = k或k = 0时,组合 ...
- JavaScript 递归法排列组合二维数组2
<html> <head> <title>二维数组排列组合</title> </head> <body> <div id= ...
随机推荐
- EventLog组件
1.使用EventLog组件读写事件日志 SourceExists方法 确定事件源是否已在本地计算机上注册 DeleteEventSource方法 用于从事件日志中移除应用程序的事件源注册 pri ...
- Automotive Security的一些资料和心得(7):AUTOSAR和Security
1. 密码模块[1] 密码模块在Services Layer Configurable and common access to 密码子程序 硬件支持密码模块 2. 应用 应用和密码子程序分离 Cry ...
- 计算器(console version)
题目描述 请用python编写一个计算器的控制台程序,支持加减乘除.乘方.括号.小数点,运算符优先级为括号>乘方>乘除>加减,同级别运算按照从左向右的顺序计算. 输入描述 数字包括& ...
- delphi xe5 android sample 中的 SimpleList 是怎样绑定的
C:\Users\Public\Documents\RAD Studio\12.0\Samples\FireMonkeyMobile 例子中的绑定方式如下图: 1.拖拽一个listview到界面上,然 ...
- WCF 服务器已拒绝客户端凭据
将 WCF 服务器和客户端分别部署到不同机器上,可能会触发如下异常. 未处理 System.ServiceModel.Security.SecurityNegotiationException M ...
- Foundation和UIKit框架图
学习Foundation和UIKit的时候比较容易忽视的一个问题: 对于一个新的类,知道它的用法和属性方法,但往往忽视了它的继承关系, 了解类的继承关系能帮助加深对其理解. 另外在官方文档中每一个类的 ...
- SPRING IN ACTION 第4版笔记-第三章ADVANCING WIRING-006-给bean运行时注入值(Environment,Property文件)
一. 直观的给bean注入值如下: @Bean public CompactDisc sgtPeppers() { return new BlankDisc( "Sgt. Pepper's ...
- ArcGis 在线地图相关资源
原文:ArcGis 在线地图相关资源 世界边界和地点:http://services.arcgisonline.com/ArcGIS/rest/services/Reference/World_Bou ...
- tomcat docBase 和 path
<Context docBase="zjzc-web-api" path="/api" reloadable="false"/> ...
- 请问什么是UTF字符串?
utf是编码方式,一般而言是国际性质的编码格式,有utf-8,utf-9,utf-16等多种形式,是最高级别的编码方式,也就是说如果你要读取的数据流设置成utf编码的话就要用到相应的编码方式来读取了, ...