1 # -*- coding:utf-8 -*- 2 3 ‘‘‘直接插入的python实现 4 时间复杂度O(n**2) 空间复杂度O(1) 稳定 5 6 思想:先将前两个元素排序,第三个元素插入前面已排好序列, 7 后面的元素依次插入之前已经排好序的序列 8 ‘‘‘ 9 10 author = ‘Leo Howell‘ 11 12 L = [89,67,56,45,34,23,1] 13 14 def direct_insert_sort(numbers): 15 for i in range(1,len(numbers)): 16 #temp变量指向尚未排好序元素(从第二个开始) 17 temp = numbers[i] 18 19 #j指向前一个元素的下标 20 j = i-1 21 22 #temp与前一个元素比较,若temp较小则前一元素后移,j自减,继续比较 23 while j>=0 and temp<numbers[j]: 24 numbers[j+1]=numbers[j] 25 j = j-1 26 27 #temp所指向元素的最终位置 28 numbers[j+1] = temp 29 30 if __name__==‘__main__‘: 31 direct_insert_sort(L) 32 print L 33
时间: 2024-12-13 22:29:02