python --- 插入排序算法

先上一张图,看看能不能从里面悟出些什么:

问题的解决思路:

      就是当插入第i个的时候,前面的[i- 1]个已经排好了,这时候lst[i]就倒过来逐个和前面的关键字顺序进行比较,找到插入位置即将lst[i]插入,原来位置上的对象整体往后移。

代码如下:

1 def insert_sort(lst):
2     for i in range(1, len(lst) - 1):
3         temp = lst[i]
4         for j in range(i - 1, -1, -1):
5             if lst[j] > temp:
6                 lst[j + 1] = lst[j]
7                 lst[j] = temp
8     return lst

首先来讲讲外层的for循环:它是从列表的第一个元素开始。(这里就有个疑问了,为什么不是从零开始呢?其实通过上面的那张图片我们可以知道,在最开始的时候会有一个初始关键字,方便跟后面的元素进行比较。),然后对整个列表进行一个循环。

然后就是内层的for循环:j是对之前已经排好了的关键字进行的一次循环,然后通过这次循环将lst[i]插入进去,当通过这次循环temp找到比它小的那个数的时候,就把temp插入进去。

注意:

    内层的循环是在已排好的列表中从后往前查找,当找到比自己小的数的时候,就插到它的后面,不能是从前往后,那样不一定可以插队正确的位置。

原文地址:https://www.cnblogs.com/tulintao/p/10750341.html