数据结构算法--6 希尔排序和计数排序

希尔排序

希尔排序与插入排序原理相同,希尔排序是一种分组插入排序算法

> 首先取一个整数d1=n/2,将元素分为d1个组,每组相邻两元素之间距离为d1,在各组内之间插入排序。

> 取第二个整数d2=n/2,重复上述分组排序过程,直到di=1,即所有元素在同一组内直接插入排序

> 希尔排序每趟并不使某些元素有序,而是使整体数据越来越接近有序;最后一趟排序使所有数据有序。

给一个数组:5,7,4,6,3,1,2,9,8

首先d=4:

数据结构算法--6 希尔排序和计数排序_第1张图片

5和3交换位置;7和1交换位置;4和2交换位置;6和9位置不变;

数组在第一轮变为3,1,2,6,5,7,4,9,8

然后d=2:

数据结构算法--6 希尔排序和计数排序_第2张图片

两组内部再次插入排序,结果变为2,1,3,6,4,7,5,9,8

最后d=1,整体插入排序使数组有序:1,2,3,4,5,6,7,8,9

> 希尔排序代码:

def insert_sort_gap(li,gap):
    for i in range(gap,len(li)):  # i 表示摸到牌的下标
        tmp=li[i]
        j=i-gap
        while j>=0 and li[j]>tmp:
            li[j+gap]=li[j]
            j-=gap
        li[j+gap]=tmp

def shell_sort(li):
    d=len(li) //2
    while d>=1:
        insert_sort_gap(li,d)
        d //=2
     

计数排序

计数排序是对列表进行排序,列表中的数大小在0到100之间,时间复杂度为O(n)

对于一个数组,我们先写出一个从0到5的数,然后在这些数后边写上每个值在列表中出现的次数

数据结构算法--6 希尔排序和计数排序_第3张图片

我们在整个数组中先写出这些统计的值的数默认为0

我们找出出现的次数后:

数据结构算法--6 希尔排序和计数排序_第4张图片

将其按大小写出:1,1,1,2,2,3,3,3,4,5

> 希尔排序代码:

def count_sort(li,max_count=100):
    count=[0 for _ in range(max_count+1)]   #生成100个0,他们的下标就是列表中的值
    for val in li:
        count[val] +=1
    li.clear()
    for ind,val in enumerate(count):
        for i in range(val):                #添加整个值的次数为val
            li.append(ind)                  

你可能感兴趣的:(算法,数据结构,排序算法)