算法导论复习(5) 线性时间排序

线性时间排序在课本中讲了三种:计数排序、基数排序和桶排序,这三种排序的时间复杂度都是θ(n)。
一.计数排序
所谓计数就是按顺序对应下标i计算某种元素在数组中出现的次数,从而得到某种元素应该在有序数组对应的位置区间内。
例如:1,6,3,2,6,1,4
设置数组A来存放示例元素,设置数组B来保存元素出现次数
A:1,6,3,2,6,1,4
B: 下标i:0 1 2 3 4 5 6
元素出现次数:0 2 1 1 1 0 2
然后进行B[i]=B[i]+B[i-1];(确定元素输出终止位置)
B: 下标i:0 1 2 3 4 5 6
元素出现次数:0 2 3 4 5 0 7
设置数组C来保存结果(有序数组)
C:1,1,2,3,4,6,7(下标从1开始遍历)

伪代码:
COUNTING-SORT(A,B,k) //A:输入数组 B:输出数组 C:临时数组
create C[0..k]
for i=0 to k
C[i]=0
for j=1 to A.length
C[A[j]]+=1
for i=1 to k
C[i]=C[i]+C[i-1]
for j=A.length downto 1
B[C[A[j]]]=A[j]
C[A[j]]-=1

特点:1.时间复杂度:第一个for和第三个for所花时间为θ(k);第二个for和第四个for所花时间为θ(n)
总时间为θ(k+n) 当k=O(n)时,用计数排序,时间为θ(n)。
2.计数排序具有稳定性

二.基数排序
这种排序比较简单,从最低有效位进行排序依次到最高位得到排序结果。
例如,将n个d位的元素存放在数组A中,其中第1位为最低位,第d位为最高位。
伪代码:
RADIX-SORT(A,d)
for i=1 to d
use a stable sort to sort array A on digit
时间复杂度:θ(d(n+k))

三.桶排序
桶排序的步骤就是将输入的数据分别放在不同的“桶”(链表)中,先在各自桶中排序,最后按照桶的顺序遍历即可。
伪代码:
BUCKET-SORT(A)
n=A.length
create B[0..n-1]
for i=0 to n-1
empty B[0..n-1]
for i=1 to n
insert A[i] into list B[nA[i]]
for i=0 to n-1
sort list B[i] with insertion sort //插入排序
concatenate the lists B[0],B[1],B[2]…B[n-1] together in order

时间复杂度:θ(n)

购物商城项目采用PHP+mysql有以及html+css jq以及layer.js datatables bootstorap等插件等开发,采用了MVC模式,建立一个完善的电商系统,通过不同用户的不同需求,进行相应的调配和处理,提高对购买用户进行配置….zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值