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;

最近更新

关于SDH的日常维护与故障分析思考 2页

关于3J22合金轴尖斑点的讨论 2页

2025年情绪管理实用技巧教学演示 53页

公共餐厨垃圾回收物流中激励机制的研究 2页

全球资料分析中重力波的重要性 2页

全国铁路水文(大中桥)学术讨论会在武汉召开 2页

全国热浸镀锌、铝技术交流会召开 2页

全国合作经济学术讨论会将在我院举行 2页

2025年呼吸机诱发肺炎的防治与护理策略 20页

2025年医院吸痰操作流程详解 35页

2025年冠状动脉疾病防治攻略 50页

2025年传统活血化瘀药材应用指南 41页

公司前台接待岗位职责(28篇) 36页

关于初中优秀作文600字4篇 5页

关于投标承诺书集锦(29篇) 51页

2025年膝关节半月板损伤精准诊断与有效治疗策.. 68页

医院新员工岗前培训方案(3篇) 12页

大学军训心得第6天范文(29篇) 57页

2025年心脏冠状动脉详细解析 42页

2025年宝宝健康急救宝典 25页

二零二五年度企业宿舍管理免责责任书 7页

二零二五年度企业品牌全案代运营合作协议 9页

二零二五年度企业员工培训安全责任合同 7页

二零二五年度企业单方解除劳动合同通知书模板.. 8页

二零二五年度企业健康文化推广与员工福祉合同.. 9页

二零二五年度代收代付业务合规操作规范协议 9页

二零二五年度人才培训合同及离职条件限制承诺.. 9页

二零二五年度人工智能与机器人技术增资协议 8页

二零二五年度产学研合作之方协议——网络安全.. 9页

最新部编版三年级下册语文全册教案 106页