算法导论复习(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)

你可能感兴趣的:(bootstrap,算法)