【算法】直接插入排序

1、排序逻辑

1.1 原理

它的基本思想是将一个记录插入到已经排好序的有序表中,从而一个新的、记录数增1的有序表。

1.2 思路

(1)第一次比较:首先比较第2个数和第1个数,将小数放在前面,将大数放在后面。第二个比第一个大,结束

(2)第二次比较:比较第3个数和第2个数,将小数放在前面,大数放在后面;比较第2个数和第1个数,将小数放在前面,大数放在后面。

(3)第三次比较:比较第4个数和第3个数,后面的数比前面的大,结束。

...

直到全部比较完毕。

2、算法分析

2.1排序逻辑总结

N个数字要排序完成,总共进行N-1趟比较,第i趟的排序次数为(N-i)次-0次不等,所以可以用双重循环语句,外层控制循环多少趟,内层控制每一趟的插入。

2.2 时间复杂度

正序情况:只需要走一趟即可完成排序。所需的比较次数C和记录移动次数M均达到最小值,即:Cmin=n-1;Mmin=0;所以,冒泡排序最好的时间复杂度为O(n)。

逆序:则需要进行n-1趟排序。每趟排序要进行n-i次比较(1≤i≤n-1),且每次比较都必须移动记录三次来达到交换记录位置。在这种情况下,比较和移动次数均达到最大值:

3、code

3.1 java

java 复制代码
public class Code03InsertionSort {
    public static void main(String[] args) {
        int[] arr = {3, 44, 38, 5, 47, 15, 36, 26, 27, 2, 46, 4, 19, 50, 48};
        insertionSort(arr);
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
    }

    public static void insertionSort(int[] arr) {
        for (int i = 1; i < arr.length; i++) {
            for (int j = i - 1; j >= 0 && arr[j] > arr[j + 1]; j--) {
                swap(arr, j, j + 1);
            }
        }
    }

    public static void swap(int[] arr, int i, int j) {
        int temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp;
    }
}

3.2 python

python 复制代码
def insert_sort(arr):
    for i in range(1, len(arr)):
        j = i
        while j > 0 and arr[j] < arr[j - 1]:
            arr[j], arr[j - 1] = arr[j - 1], arr[j]
            j -= 1


if __name__ == '__main__':
    arr = [3, 44, 38, 5, 47, 15, 36, 26, 27, 2, 46, 4, 19, 50, 48]
    insert_sort(arr)
    print(arr)
相关推荐
AC赳赳老秦几秒前
CSV大文件处理全流程:数据清洗、去重与格式标准化深度实践
大数据·开发语言·人工智能·python·算法·机器学习·deepseek
YIN_尹3 分钟前
CANN开源仓Catlass模板库核心能力与编程实战
java·开源·dubbo
华如锦4 分钟前
微调—— LlamaFactory工具:使用WebUI微调
java·人工智能·python·ai
AndrewHZ5 分钟前
【图像处理基石】光线追踪(Ray Tracing)算法入门
图像处理·人工智能·算法·计算机视觉·计算机图形学·光线追踪·渲染技术
武子康8 分钟前
Java-215 RocketMQ 消费模式:Push vs Pull 的本质、长轮询机制与 Offset/积压调优要
java·大数据·分布式·消息队列·rocketmq·java-rocketmq·mq
侧耳倾听11110 分钟前
分布式ID之雪花算法
java·分布式
橘颂TA10 分钟前
【剑斩OFFER】算法的暴力美学——两数相加
c++·算法·结构与算法
youngee1111 分钟前
hot100-54在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
大叔_爱编程11 分钟前
基于人脸识别的互联网课堂考勤系统-springboot
java·spring boot·毕业设计·人脸识别·源码·课程设计·课堂考勤系统
草莓熊Lotso11 分钟前
《算法闯关指南:递归,搜索与回溯算法--递归》--02. 合并两个有序链表,03. 反转链表
运维·数据结构·算法·链表