当前位置: 首页 > news >正文

插入排序(排序算法)

文章目录

  • 插入排序
    • 详细代码

插入排序

插入排序,类似于扑克牌的玩法一样,在有序的数组中,扫描无序的数组,逐一的将元素插入到有序的数组中。

实现细节:

  1. 从第一个元素开始,该元素可以认为已经被排序
  2. 取出下一个元素,已经排序的元素序列中从后向前扫描,逐一的插入到有序数组中。
  3. 如果有序数组的元素(已排序)大于新元素,将该元素移到下一位置
  4. 重复步骤3,直到找到已排序的元素小于或者等于新元素的位。
  5. 将新元素插入到该位置中

详细代码

package sort;/*** 作者:Hui* 时间:2024-06-06*//***** @author: Hui**/
public class InsertSort {public static void main(String[] args) {//初始化数组int[] arr = {1, 5, 3, 456, 5, 6, 7, 13, 9, 100};System.out.println("排序前:" );for (int i = 0; i < arr.length; i++) {System.out.println(arr[i]);}InsertSort insertSort = new InsertSort();insertSort.insertSortMethod(arr);System.out.println("排序后:" );for (int i = 0; i < arr.length; i++) {System.out.println(arr[i]);}}//插入排序,类似于扑克牌的玩法一样//            1.从第一个元素开始,该元素可以认为已经被排序//            2.取出下一个元素,已经排序的元素序列中从后向前扫描,逐一的插入到有序数组中。//            3.如果有序数组的元素(已排序)大于新元素,将该元素移到下一位置//            4.重复步骤3,直到找到已排序的元素小于或者等于新元素的位。//            5.将新元素插入到该位置中public int[] insertSortMethod(int arr[]){//1.从第一个元素开始,该元素可以认为已经被排序for (int i = 1; i < arr.length; i++) {int temp = arr[i];int j = i;while (j > 0 && temp < arr[j -1]){    //该元素(已排序)大于新元素arr[j] = arr[j - 1]; //将该元素移到下一位置j--;}if (j != i){arr[j] = temp;    //5.将新元素插入到该位置中}}return null;}
}

我是小辉,24 届毕业生。当下是找工作ing,欢迎关注,持续分享。

http://www.lryc.cn/news/371349.html

相关文章:

  • 【附带源码】机械臂MoveIt2极简教程(六)、第三个demo -机械臂的避障规划
  • innovus:route secondary pg pin
  • btstack协议栈实战篇--LE Peripheral - Test Pairing Methods
  • git下载项目登录账号或密码填写错误不弹出登录框
  • 平移矩阵中的数学思考
  • 【机器学习】Qwen2大模型原理、训练及推理部署实战
  • JetLinks开源物联网平台社区版部署教程
  • QT学习过程中遇到的问题自记
  • 自学网络安全的三个必经阶段(含路线图)
  • gitlab下载及安装
  • YOLOv10改进|采用ADown降采样模块有效融合
  • libGL.so.1: cannot open shared object file: No such file or directory
  • 2024年消防设施操作员考试题库及答案
  • 30字以内免费翻译维吾尔语,汉维翻译工具推荐,维吾尔文字母OCR识别神器《维汉翻译通》App!
  • 省市县选择三级联动(使用高德API实现)
  • 【数据结构(邓俊辉)学习笔记】图06——最小支撑树
  • 海豚调度清理:使用 API 轻松清理历史工作流实例以及日志文件
  • python怎么显示行号
  • pytorch中,load_state_dict和torch.load的区别?
  • ObjectARX打印当前图纸为PDF,无延迟(亲测有效)
  • torch.squeeze() dim=1 dim=-1 dim=2
  • 智慧环保一体化平台简介
  • idea在空工程中添加新模块并测试的步骤
  • HCIE-QOS基本原理
  • pycharm基本使用(常用快捷键)
  • 机器学习--回归模型和分类模型常用损失函数总结(详细)
  • 企业选择数字工厂管理系统供应商的标准是什么
  • 京准电钟|基于纳秒级的GPS北斗卫星授时服务器
  • Flutter知识点
  • 2024-06-12 问AI: 在大语言模型中,什么是Jailbreak漏洞?