插入排序+思路分析

图解

在这里插入图片描述

代码实现

package com.atguigu.sort;import java.util.Arrays;/*** @创建人 wdl* @创建时间 2021/3/22* @描述*/
public class InsertSort {public static void main(String[] args) {int[] arr={101,34,119,1};insertSort(arr);}//插入排序public static void insertSort(int[] arr){//使用for循环来把代码简化for (int i = 1; i < arr.length; i++) {//定义待插入的数int insertVal=arr[i];int insertIndex=i-1;//即arr[1]的前面这个数的下标//给insertVal找到插入的位置//说明//1.insertIndex>=0保证在给insertVal找插入位置,不越界//2.insertVal<arr[insertIndex] 待插入的数,还没有找到插入位置//3.就需要将arr[insertIndex]后移while (insertIndex>=0&&insertVal<arr[insertIndex]){arr[insertIndex+1]=arr[insertIndex];//arr[insertIndex]insertIndex--;}//当退出while循环时,说明插入的位置找到,insertIndex+1arr[insertIndex+1]=insertVal;System.out.println("第"+i+"轮插入");System.out.println(Arrays.toString(arr));}//        //使用逐步推导的方式来讲解,便利理解
//        //第1轮{101,34,119,1}=>{34,101,119,1}
//
//        //定义待插入的数
//        int insertVal=arr[1];
//        int insertIndex=1-1;//即arr[1]的前面这个数的下标
//
//        //给insertVal找到插入的位置
//        //说明
//        //1.insertIndex>=0保证在给insertVal找插入位置,不越界
//        //2.insertVal<arr[insertIndex] 待插入的数,还没有找到插入位置
//        //3.就需要将arr[insertIndex]后移
//        while (insertIndex>=0&&insertVal<arr[insertIndex]){
//            arr[insertIndex+1]=arr[insertIndex];//arr[insertIndex]
//            insertIndex--;
//        }
//        //当退出while循环时,说明插入的位置找到,insertIndex+1
//        arr[insertIndex+1]=insertVal;
//        System.out.println("第1轮插入");
//        System.out.println(Arrays.toString(arr));
//
//
//
//        //第二轮
//        //定义待插入的数
//        insertVal=arr[2];
//        insertIndex=2-1;//即arr[1]的前面这个数的下标
//
//        //给insertVal找到插入的位置
//        //说明
//        //1.insertIndex>=0保证在给insertVal找插入位置,不越界
//        //2.insertVal<arr[insertIndex] 待插入的数,还没有找到插入位置
//        //3.就需要将arr[insertIndex]后移
//        while (insertIndex>=0&&insertVal<arr[insertIndex]){
//            arr[insertIndex+1]=arr[insertIndex];//arr[insertIndex]
//            insertIndex--;
//        }
//        //当退出while循环时,说明插入的位置找到,insertIndex+1
//        arr[insertIndex+1]=insertVal;
//        System.out.println("第2轮插入");
//        System.out.println(Arrays.toString(arr));
//
//        //定义待插入的数
//        insertVal=arr[3];
//        insertIndex=3-1;//即arr[1]的前面这个数的下标
//
//        //给insertVal找到插入的位置
//        //说明
//        //1.insertIndex>=0保证在给insertVal找插入位置,不越界
//        //2.insertVal<arr[insertIndex] 待插入的数,还没有找到插入位置
//        //3.就需要将arr[insertIndex]后移
//        while (insertIndex>=0&&insertVal<arr[insertIndex]){
//            arr[insertIndex+1]=arr[insertIndex];//arr[insertIndex]
//            insertIndex--;
//        }
//        //当退出while循环时,说明插入的位置找到,insertIndex+1
//        arr[insertIndex+1]=insertVal;
//        System.out.println("第3轮插入");
//        System.out.println(Arrays.toString(arr));
//
//}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/326888.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

.NET 十五岁,谈谈我眼中的.NET

2002年2月13日&#xff0c;第一个版本随着visual studio.net的发布&#xff0c;今天已经走过15年, .net团队写了一篇文章&#xff0c;里面有一个视频&#xff0c;Anders Hejlsberg已是白发苍苍的老人&#xff0c;我也从刚出校门的码农长成软件开发工程师&#xff0c;我爱编程。…

中国朝代及首都

朝 代 起 讫 都 城 今 地 夏 约前2146-1675年 安邑 山西夏县 ①商 约前1675-1029年 亳 河南商丘 周 西周 ②约前1029-771年 镐京 陕西西安 东周 前770-256年 洛邑 河南洛阳 秦 前221-207年 咸阳 陕西咸阳 汉 ③西汉 前206—公元25 长安 陕西西安 东汉 25—220 洛阳 河南洛阳 三…

什么注解可以改变BigDecimal类型的字段返回的小数位数?

什么注解可以改变BigDecimal类型的字段返回的小数位数&#xff1f;_myme95的博客-CSDN博客 问题背景&#xff1a;我在数据库里有一个字段&#xff0c;是decimal(20,15)类型&#xff0c;但是我在代码里返回数据给前端时&#xff0c;我要返回5位小数给前端。那么怎么转换BigDecim…

ThreadLocal的非数据安全用法

启发于同学处理的bug&#xff0c;他遇到的问题是&#xff1a; “有三台Tomcat服务器&#xff0c;其中有一台Tomcat服务器出现这种情况&#xff1a;一个用户A登录了系统&#xff0c;如果有新的用户B接着登录系统&#xff0c;会把用户A的登录信息给替换成新用户B的信息。这造成无…

理解并从头搭建redis集群

部分开发人员工作当中只是在应用中使用redis&#xff0c;比如用来做数据结果的缓存。而且现在有很多不错的redis客户端工具(redisson)&#xff0c;基本上可以不用关注redis命令就可以完成相当部分的功能。所以可能会对如下这些问题关注点不够&#xff1a; 如何容灾&#xff1f;…

希尔排序+过程分析

图解 代码实现 package com.atguigu.sort;import java.util.Arrays;/*** 创建人 wdl* 创建时间 2021/3/22* 描述*/ public class ShellSort {public static void main(String[] args) {int[] arr {8, 9, 1, 7, 2, 3, 5, 4, 6, 0};shellSort(arr);}//使用逐步推导的方式来编写…

mybatis报错Type interface xxx.Dao is not...

今天在做mybatis的时候&#xff0c;遇到一个错误&#xff0c;大家看看这个错误吧&#xff1a;org.apache.ibatis.binding.BindingException: Type interface cn.mybatis_chop10_1.dao.IEmpDao is not known to the MapperRegistry.我前找找后找找&#xff0c;就是找不出来&…

win10打字突然变成繁体

win10打字突然变成繁体 按住CtrlShiftF&#xff0c;即可在繁体与为简体间切换。

Java 程序员必须掌握的 5 个注解

转载自 Java 程序员必须掌握的 5 个注解 自 JDK5 推出以来&#xff0c;注解已成为Java生态系统不可缺少的一部分。虽然开发者为Java框架&#xff08;例如Spring的Autowired&#xff09;开发了无数的自定义注解&#xff0c;但编译器认可的一些注解非常重要。 在本文中&#xff…

Docker4Dev#7 使用 Windows Container运行ASP.NET MVC 2 + SQLExpress 应用

上一篇Windows Container文章中给大家介绍了如何使用Windows Container运行一个传统的.net 4.5 web应用程序&#xff0c;当时我们使用了默认的Visual Studio模版创建了一个简单的项目&#xff0c;而且没有链接数据库。我相信使用.net进行应用开发的程序员们一定在想&#xff0c…

Mybatis+MySQL动态分页查询数据经典案例

最近在用Mybatis做项目的时候遇到了不少问题&#xff0c;今天我就在这和大家分享一下&#xff0c;稀稀拉拉的研究了两天&#xff0c;终于搞好了&#xff01;开发人员&#xff1a;1111开发软件&#xff1a;Myeclipse用到的框架技术&#xff1a;Mybatis数据库&#xff1a;MySql主…

希尔排序+移位法(吊打交换法)

package com.atguigu.sort;import java.text.SimpleDateFormat; import java.util.Arrays; import java.util.Date;/*** 创建人 wdl* 创建时间 2021/3/22* 描述*/ public class ShellSort {public static void main(String[] args) { // int[] arr {8, 9, 1, 7, 2, 3, …

那些年的骗子

中午一觉睡醒之后&#xff0c;忽然发现多年不联系的初中同学给我发了个消息&#xff0c;觉得事情没那么简单&#xff1a;正好我的公众号需要大量的用户&#xff0c;我就顺水推舟了&#xff01;一看到QQ的安全提示&#xff0c;我就感觉事情确实不妙&#xff01;初步推断对方是个…

干货 | 彻底弄懂 HTTP 缓存机制及原理

转载自 干货 | 彻底弄懂 HTTP 缓存机制及原理 前言 Http 缓存机制作为 web 性能优化的重要手段&#xff0c;对于从事 Web 开发的同学们来说&#xff0c;应该是知识体系库中的一个基础环节&#xff0c;同时对于有志成为前端架构师的同学来说是必备的知识技能。 但是对于很多…

实习知识整理7:SpringBoot和html+thymeleaf模板的项目的相关配置文件

1. application.yml server: port: 8082servlet:context-path: /project #设置访问地址 http://localhost:8082/project 才可以访问到 static 下 index.htmlspring:datasource: # 数据库driver-class-name: com.mysql.cj.jdbc.Driver # 这是8的配置&#xff0c;5的话不用…

Visual Basic的未来之路

上周&#xff0c;微软宣布了他们改变Visual Basic语言未来发展计划的想法。这次公布给Visual Basic开发人员留下了很多不确定性&#xff0c;但Visual Basic语言的设计者Anthony D.Green说明了这个新策略的一些细节。 Green首先列出了当时使用VB进行开发的四个基础指导原则&…

快速排序+思路分析

图解 代码实现 package com.atguigu.sort;import com.sun.org.apache.xpath.internal.WhitespaceStrippingElementMatcher;import java.util.Arrays;/*** 创建人 wdl* 创建时间 2021/3/22* 描述*/ public class QuickSort {public static void main(String[] args) {//[-9,78,…

jquery sleep函数

function sleep(n) { //n表示的毫秒数 var start new Date().getTime(); while (true) if (new Date().getTime() - start > n) break; } console.log(new Date()); this.sleep(3000); console.log(new Date());

2017 年编程语言排行榜:Python 排第一

站长之家(ChinaZ.com) 7 月 24 日消息&#xff0c;近日根据 IEEE Spectrum 发布的研究报告显示&#xff0c;在 2016 年排名第三的 Python 在今年已经成为世界上最受欢迎的语言&#xff0c;C 和 Java 分别位居第二和第三位。IEEE Spectrum 的排行依据数据记者 Nick Diakopoulos …

Spring 获取 request 的几种方法及其线程安全性分析

转载自 Spring 获取 request 的几种方法及其线程安全性分析 本文将介绍在Spring MVC开发的Web系统中&#xff0c;获取request对象的几种方法&#xff0c;并讨论其线程安全性。 一、概述 在使用Spring MVC开发Web系统时&#xff0c;经常需要在处理请求时使用request对象&…