【学习记录 · 9.2】数据结构与算法 学习第三天 排序

【教 材】:《数据结构(C/C++)》 熊回香清华大学出版社、北京交通大学出版社

【章 节】:第 9 章  排序

【内 容】:

9.1 排序的基本概念

1. 关  键  字:数据元素集合中的一个域;排序依据。

    主关键字:能够唯一区分各个不同数据元素的关键字。

    次关键字:其他关键字。

排序依据(即排序关键字)可以是主关键字,排序后结果唯一;也可以是次关键字,不同排序方法会产生不同结果,根据具有相同关键字的元素的相对次序,分为次序不变的稳定排序,和次序改变的不稳定排序。进行以数字为关键字进行正序排列,

原始序列:(2,d)(3,c)(3,b)(1,a)

结    果一:(1,a)(2,d)(3,c)(3,b)

果二:(1,a)(2,d)(3,b)(3,c)

   稳定排序的结果必为“结果一”;不稳定排序的结果可能为“结果一” 或“结果二”。

2. 排序方法评价要素

1)时间性能;2)空间性能;3)稳定性;4)线性存储结构,分为链式(链表等)和顺序存储(数组等)。

9.2 插入排序

1. 基本思想关键字:初始有序或基本有序,子集合,新元素插入。

2. 直接插入排序(straight insert sort)

代码:

算法考察:

1)时间性能  最好  O(n);最坏 O(n^2);平均 O(n^2) 。

2)空间性能  临时工作单元temp,耗费O(1)个存储空间。

3)稳定性能 稳定排序。

拓展:通过二分法查找可减少比较次数,但不改变平均资源消耗。

3. 希尔排序(shell sort )

基本思想关键字:跳跃分割,分组排序,基本有序

代码:

增量序列:
1)Shell di = N / (2^i) ;
2)Sedgewickdi = 9*4^i - 9*2^i + 1;或di = 4^i - 3*2^i + 1(从i = 2开始);
算法考察:
1)时间性能 平均消耗低于O(n^2);实际应用中,Sedgewick 增量序列为目前最优序列,理论上尚未证明。
2)空间性能 临时工作单元temp,耗费O(1)个存储空间。
3)稳定性能不稳定排序。
【总 结】:
经典的书未必适合初学者。维斯的《数据结构与算法分析》偏重于解决“为什么”的内容,需要有一定的基础(熟练掌握各种排序的实现),不太适合初学者。
《数据结构(C/C++)》使用的是10年的版本。此书在算法的具体实现方面讲得较为清楚,但代码风格不如国外经典书籍清晰,且多有谬误。
代码风格感觉有两个目标:一是效率,利用适当的算法,减少资源和时间的使用,使代码更有效;二是清楚,逻辑清楚,便于理解与阅读。之前,编写“巧妙的”代码更容易引起我的兴趣,但今天对比两本书后发现,有时候多写两行代码,在计算机资源消耗上引起的变化微乎其微,但代码会更清楚,逻辑会更清晰。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值