插入排序算法

插入排序算法的原理:

两个数组,把一个数组拆分成两部分,前面的是有序数组,后面的是无序数组,然后依次把后面无序的数组和前面有序的数组进行比较放到合适的位置,直到把最后一个数放入到有序数组中。

例如:int[] a = {5, 3, 2, 4, 1}, 把分成有序m(为了方便表示)和0无序n,m一开始没有元素,然后把n中的5插入到m中,你会发现5进入时不需要进行比较直接插入就行,所以可以把m设置为一开始存在a中的第一个元素,循环的次数从1开始。插入5之后然后再插入3,3比5小,所以交换位置,交换位置后发现3前面没有数了,所以进行下次的插入操作插入2,2比5小交换位置,2又比3小交换位置...... 一直到最后无序的数组中的元素全部插入到有序数组中。

插入时分两种情况:

1.插入的数小于比较的数交换位置,直到遇到大于比较数的位置。

2.插入的数大于比较的数不用交换,当前位置就是插入数有序数组的位置,然后退出循环。

Java代码:

java 复制代码
package Sort;

public class InsertSort {
    //插入排序方法一:
    public static void insertSort1(int[] a){
        int len = a.length;
        //数组为空或者只有一个元素,则不需要排序
        if(a == null || len < 2){
            return;
        }
        //插入排序0位置已经排序号了,所以从1开始
        for(int i = 1; i < len; i++){
            int newNum = i;
            //从i位置开始,向前寻找插入位置
            //循环条件:newNum左边有数且newNum - 1位置的数比newNum位置的数大
            while(newNum - 1 >= 0 && a[newNum - 1] > a[newNum]){
                Swap(a, newNum - 1, newNum);  //交换位置
                newNum--;  //向左移动继续向前寻找插入位置
            }
        }
    }

    //插入排序方法二:
    public static void insertSort2(int[] a){
        int len = a.length;
        //数组为空或者只有一个元素,则不需要排序
        if(a == null || len < 2){
            return;
        }
        //插入排序0位置已经排序号了,所以从1开始
        for(int i = 1; i < len; i++){
            //新插入的数从排好顺序的最后开始比较
            for(int j = i; j > 0; j--){
                //如果小于交换两个数
                if(a[j] < a[j - 1]) Swap(a, j, j - 1);
                //否则结束循环
                else break;
            }
        }
    }

    public static void Swap(int[] a, int i, int j){
        int temp = a[i];
        a[i] = a[j];
        a[j] = temp;
    }
    public static void sortprint(int[] a){
        for(int i = 0; i < a.length; i++){
            System.out.print(a[i] + " ");
        }
        System.out.println();
    }
    public static void main(String[] args) {
        int[] a = {5, 3, 2, 4, 1};

        sortprint(a);
        insertSort2(a);
        sortprint(a);
    }
}
相关推荐
灵感__idea18 小时前
Hello 算法:众里寻她千“百度”
前端·javascript·算法
Wect1 天前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
NAGNIP2 天前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱2 天前
单调栈:从模板到实战
javascript·后端·算法
是希燃亚2 天前
📚 十大经典排序算法 C语言笔记(一看就会版)
排序算法
CoovallyAIHub2 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉