十大排序——6.插入排序

这篇文章我们来介绍一下插入排序

目录

1.介绍

2.代码实现

3.总结与思考


1.介绍

插入排序的要点如下所示:

首先将数组分为两部分[ 0 ... low-1 ],[ low ... arr.length-1 ],然后,我们假设左边[ 0 ... low-1 ]是已排好序的部分右边[ low ... arr.length-1 ]是未排序的部分,然后每次从未排序的部分取出low位置的元素,插入到已排序区域

过程实例:

初始数据:**65,****27,**59,64,58

**【27,65】59,**64,58

**【27,59,65】64,**58

【27,59,64,65】58

【27,58,59,64,65】

**第一次插入:**把数组分为[ 65 ]和[ 27,59,64,58 ] 两部分,然后后面一组的第一个元素即27插入到前面一直中,即把27和65进行比较,27<65,把27插入到65前面,此时【27,65】为一个有序列,后面属于无序列

**第二次插入:**把数组分为[ 27,65 ]和[59,64,58 ] 两部分,然后后面一组的第一个元素即59插入到前面一直中,即把59与65比较,59<65,把59和27比较,59>27,把59插入到27与65之间(后面数据与前面有序列的比较其实就是冒泡排序)

以此类推;

2.代码实现

这次的代码实现分为递归实现和非递归实现两种,供大家参考

java 复制代码
package Sorts;

import java.util.Arrays;
//插入排序
public class InsertSort {
    public static void main(String[] args) {
        int [] arr = new int[]{5,9,2,7,3,1,10};
        Insert2(arr);
        System.out.println(Arrays.toString(arr));
    }
    //递归版的方法
    public static void Insert1(int[]arr, int low){
        if (low == arr.length)
            return;
        int t = arr[low];
        int i = low-1;
        //从右向左找插入位置,如果比待插入元素大,则不断右移,空出插入位置
        while (i >= 0 && t <arr[i]){
            arr[i+1] = arr[i];
            i--;
        }
        //找到插入位置
        if (i+1 != low){
            arr[i+1] = t;
        }
        Insert1(arr,low+1);
    }

    public static void Insert2(int[]arr){
        for (int low = 1; low < arr.length-1 ; low++) {
            int t = arr[low];
            int i = low-1;
            //从右向左找插入位置,如果比待插入元素大,则不断右移,空出插入位置
            while (i >= 0 && t <arr[i]){
                arr[i+1] = arr[i];
                i--;
            }
            //找到插入位置
            if (i+1 != low){
                arr[i+1] = t;
            }
        }
    }
}

3.总结与思考

插入排序,一听名字应该就能知道它的逻辑是怎么样的。分两个数组,从无序数组中拿数据往有序数组中插入,并且插入到正确位置。难点就在于怎么插入,这个可以看上面代码的演示。

相关推荐
dazzle10 小时前
机器学习算法原理与实践-入门(十一):基于PyTorch的房价预测实战
pytorch·算法·机器学习
袋鼠云数栈17 小时前
集团数字化统战实战:统一数据门户与全业态监管体系构建
大数据·数据结构·人工智能·多模态
小月球~17 小时前
天梯赛 · 并查集
数据结构·算法
仍然.18 小时前
算法题目---模拟
java·javascript·算法
三道渊19 小时前
C语言:文件I/O
c语言·开发语言·数据结构·c++
kali-Myon20 小时前
CTFshow-Pwn142-Off-by-One(堆块重叠)
c语言·数据结构·安全·gdb·pwn·ctf·
潇冉沐晴20 小时前
DP——背包DP
算法·背包dp
GIOTTO情20 小时前
2026 世界互联网大会亚太峰会|AI 时代媒介投放的技术实战与算法优化
人工智能·算法
逆境不可逃21 小时前
LeetCode 热题 100 之 543. 二叉树的直径 102. 二叉树的层序遍历 108. 将有序数组转换为二叉搜索树 98. 验证二叉搜索树
算法·leetcode·职场和发展
计算机安禾21 小时前
【数据结构与算法】第19篇:树与二叉树的基础概念
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio