一、插入排序
插入排序的基本思想是将一个记录插入到已经排好序的有序表中,从而形成一个新的、记录数增1的有序表。
排序过程:
1、外层循环:从第二个元素开始,依次选取未排序的元素。
2、内层循环:将当前选取的元素与已排序序列中的元素从后往前进行比较,找到合适的插入位置,并将比它大的元素向后移动一位,为新元素的插入腾出空间。
3、插入操作:将当前元素插入到找到的位置上,完成一次插入操作。
插入排序的时间复杂度在最好情况下是O(N),在平均和最坏情况下是O(N^2),其中N是列表的长度
# -*- coding: utf-8 -*-
"""
======================================
File Name :insertion_sort.py
Author :lanmingyong
date :2024/4/19 17:04
Description:
插入排序的基本思想是将一个记录插入到已经排好序的有序表中,从而形成一个新的、记录数增1的有序表。它通过双层循环来实现排序过程:
外层循环:从第二个元素开始,依次选取未排序的元素。
内层循环:将当前选取的元素与已排序序列中的元素从后往前进行比较,找到合适的插入位置,并将比它大的元素向后移动一位,为新元素的插入腾出空间。
插入操作:将当前元素插入到找到的位置上,完成一次插入操作。
插入排序的时间复杂度在最好情况下是O(N),在平均和最坏情况下是O(N^2),其中N是列表的长度
=======================================
"""
def insertion(arr):
for i in range(1, len(arr)):
index = i
for j in list(range(i))[::-1]:
if arr[index] < arr[j]:
arr[index], arr[j] = a