1 / 10
文档名称:

数据结构排序算法.docx

格式:docx   页数:10页
下载后只包含 1 个 DOCX 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

数据结构排序算法.docx

上传人:799474576 2015/5/29 文件大小:0 KB

下载得到文件列表

数据结构排序算法.docx

文档介绍

文档介绍:常见排序算法总结
1. 基本概念
排序:是将一组数据元素按某种特定要求(升或降序)排列成有规律序列的过程。
排序可以分为内部排序和外部排序两种:
1). 若整个排序过程不需要访问外存便能完成,则称此类排序为内部排序。
2). 若参加排序的记录数量很大,整个序列的排序过程不可能在内存中完成,需要借助外存来完成,则称此类排序为外部排序。//不涉及内外存交换
就地排序:若排序算法所需的辅助空间并不依赖于问题的规模n,即辅助空间为O(1),则称为就地排序。
稳定性:假设在待排序的元素中,存在两个或两个以上的元素具有相同的关键字,在用某种排序法排序后,若这些相同关键字的元素的相对次序仍然不变,则这种排序方法是稳定的。
2. 常见内部排序
交换排序
交换排序的基本思想是两两比较待排序记录的关键字,若发生与排序要求相逆,则交换之,反复进行,直到数据有序。
交换排序的主要方法有:冒泡排序和快速排序。
1). 冒泡排序
a. 算法思想
已知一组无序数据元素P[n],需将按其关键字升序排列。
第一趟对n个元素冒泡得到一个关键字最大的元素P[n-1],第二趟冒泡对n-1个元素得到一个关键字最大的元素P[n-2],依次类推,直到数据有序。
b. 算法实现
void buble(int arr[], int n)
{
bool flag;//用于判断是否发生了交换
int i;
int temp;//临时变量
//反复多轮,从小到大排序。
do {
//一轮排序
flag = false;
//反复比较所有相邻的元素,循环比较n-1次。
for(i = 1; i < n; i++) {
//如果顺序不当,就交换他们。
if(arr[i] < arr[i - 1]) {
temp = arr[i];
arr[i] = arr[i - 1];
arr[i - 1] = temp;
//记录本轮已发生交换
flag = true;
}
}
n--;
}while(flag);//知道本轮没有发生交换,循环退出。
}
注:
冒泡排序算法是稳定的,时间复杂度是O(n^2)。
冒泡排序算法适合只有少量乱序的数据。
2). 快速排序
a. 算法思想
已知一组无序数据元素P[n],需将按其关键字升序排列。
首先任取一个元素P[x](通常选取首元素)作为基准,多次比较P[x]与其它元素并交换。
直到当P[x]可以排在序列的第k位,并且使P[0]~P[k]中的每一个元素小于P[x],P[k+1]~P[n-1]中的每一个元素不小于P[x]时,交换P[x]和P[k]。
再分别对P[0]~P[k-1]和P[k+1]~P[n-1]两组数据元素重复上述过程,直到数据有序。
b. 算法实现
//交换函数
void swap(int *a, int *b)
{
int temp;
temp = *a;
*a = *b;
*b = temp;
}
//快速排序
void qsort(int arr[], int n)
{
int temp;
int *L, *R;

最近更新

《物流信息化》 31页

大数据与社会治理模式的创新-全面剖析 30页

代谢途径中关键蛋白质鉴定-全面剖析 31页

催化氧化法处理含氰废水机理的探讨 2页

俄罗斯岩土工程研究成果和发展水平 2页

低阶煤热演化生烃的模拟试验研究 2页

位置灵敏半导体探测器的测试原理和方法 2页

煤矿电气产品购销合同协议 7页

以成组技术为基础的成批生产装配自动化 2页

深圳房屋租赁合同电子版样本转让与许可合同 6页

从卫星影像上分析海南岛第四纪玄武岩的分期 2页

介绍一种打印人体生物节律曲线的方法 2页

人工挖孔灌注桩在高速公路施工中的应用 2页

交通运输行业信息化绩效评价体系研究 2页

井下刮板输送机电动机故障原因与处理方法 2页

云南新型工业化与信息化融合问题探讨 2页

汽油供应合同协议书范文 6页

为提高劳动科学研究水平而努力奋斗 2页

毕业生档案托管服务合同协议书样本 7页

中小企业电子商务绩效衡量研究 2页

中国纯碱工业科学技术专家网正式建立 2页

中国建筑科学研究院工程抗震研究所简介 2页

中厚度圆浮板自由振动的一个解析解 2页

东欧经济现状和对西方采取的对策 2页

不溶性阳极与离子交换系统组合的回收镍盐新技.. 2页

上海市肿瘤防治研究学术交流会报道 2页

2025年幼儿园教师活动方案大全 27页

2025年吕梁职业技术学院单招职业适应性测试题.. 74页

煤矿春季预防性电气试验试措施样板 18页

2025届高考模拟作文“时间管理”升格导写 5页