知行编程网知行编程网  2023-01-14 16:30 知行编程网 隐藏边栏  6 
文章评分 0 次,平均分 0.0
导语: 本文主要介绍了关于python如何实现插入排序?的相关知识,希望可以帮到处于编程学习途中的小伙伴



python是如何实现插入排序的?



Python会遇到很多关于排序的问题。今天小编就给大家带来一种实现插入排序的方法。 python中的插入排序


基本原理类似于抽牌,将抽到的牌插入合适的位置。具体实现请看这篇文章。


基本原理


类似于摸牌,将摸起来的牌插入到合适位置。



代码:

# -*- coding: utf-8 -*-
'''
插入排序:
    类似于摸牌,从牌堆中摸一张牌,和手中现有手牌比较。若大则放右边,小放左边。
'''
def insert_sort(input_list):

    if len(input_list)<=1:
        return input_list

    for right in range(1,len(input_list)): # 开始从牌堆中摸牌
        val = input_list[right]            # 当前摸牌的值
        for left in range(0,right):        # 循环和手中牌进行比较
            if val <= input_list[left]:    # 若<最左边的牌了
                input_list[left+1:right+1]=input_list[left:right]
                input_list[left]=val
                break
    return input_list
if __name__ == '__main__':
    pre_list = [1,6,3,3,7]
    res = insert_sort(pre_list)
    print(res)



易忘点和易错点


a. 不要忘记列表长度为1的情况。

b.注意break的使用和位置,放在if语句下面。如果放在第二层for循环下面,会一直循环下去。

以上就是用Python实现插入排序的代码。需要的朋友可以直接申请~希望对你有帮助~

本文为原创文章,版权归所有,欢迎分享本文,转载请保留出处!

知行编程网
知行编程网 关注:1    粉丝:1
这个人很懒,什么都没写
扫一扫二维码分享