已知一个数组 60、28、41、39、6 、18 、14、28、49、31 利用插入排序算法进行排序

插入排序是一个运行时间为O(N²)的排序算法。

算法思想

 60、28、41、39、6 、18 、14、28、49、31  数组元素

0、  1、  2、  3、  4、 5、   6、  7、  8、  9    数组下标

先将index[0]与index[1]有序,可视为index[1]为那个 插入元素

其次将index[0]、index[1]、index[2]有序,将index[2]视为 插入元素

再其次将index[0]、index[1]、index[2]、index[3]有序,将index[3]视为 插入元素

...........

插入排序始终保持数组左侧有序,将下标从左往右依次移动,使得数组依次有序。因此对于 数组在排序之前就局部有序, “插入排序的效率将会提高”会比冒泡排序更好。

以下采用java实现

public class InsertOrder {

private int[] Array;

private int index;

private int maxIndex;

public InsertOrder(int size) {
         this.Array = new int[size];
         this.index = 0;
         this.maxIndex = size-1;
}

public void insert(int i) {
     if(this.maxIndex<this.index) {
           System.out.println("数组已满");
     }else {
           this.Array[this.index++] = i;
     }
}

public void order() {
        for(int i=1; i<=this.maxIndex;i++) {
               int temp = this.Array[i];//插入值
               int tempIndex = i;
               while(tempIndex>0&&this.Array[tempIndex-1]>temp) {
                         this.Array[tempIndex] = this.Array[tempIndex-1];
                         tempIndex=tempIndex-1;
                }
                this.Array[tempIndex]=temp;
         }
}

public void show() {
        for (int i : Array) {
             System.out.println(i);
         }
}

}

最终结果6、14、18、28、28、31、39、41、49、60

插入排序 思想 JAVA实现的更多相关文章

  1. java 用插入排序思想,对不规则数组排序。

    知道插入排序后,无意中发现,用插入排序思想,对不规则数组排序的排序 发现和许多大神写的不一样,大神写的简洁多了.--------

  2. 直接插入排序之Java实现

    直接插入排序之Java实现 一.方法一 package cn.com.zfc.lesson21.sort; import java.util.Arrays; /** * * @title Insert ...

  3. 排序算法入门之插入排序(java实现)

    插入排序思想:相当于插入元素,对于第i个元素,i之前的元素已经是有序的了,这时候将第i个元素依次与前面元素比较,插入合适的位置.

  4. 基本算法思想Java实现的详细代码

    基本算法思想Java实现的详细代码 算法是一个程序的灵魂,一个好的算法往往可以化繁为简,高效的求解问题.在程序设计中算法是独立于语言的,无论使用哪一种语言都可以使用这些算法,本文笔者将以Java语言为 ...

  5. 33.JAVA编程思想——JAVA IO File类

    33.JAVA编程思想--JAVA IO File类 RandomAccessFile用于包括了已知长度记录的文件.以便我们能用 seek()从一条记录移至还有一条:然后读取或改动那些记录. 各记录的 ...

  6. 排序系列 之 折半插入排序算法 —— Java实现

    基本思想: 折半插入算法是对直接插入排序算法的改进,排序原理同直接插入算法: 把n个待排序的元素看成一个有序表和一个无序表,开始时有序表中只有一个元素,无序表中有n-1个元素:排序过程即每次从无序表中 ...

  7. 排序系列 之 直接插入排序算法 —— Java实现

    直接插入排序算法 基本思想: 把n个待排序的元素看成一个有序表和一个无序表,开始时有序表中只有一个元素,无序表中有n-1个元素:排序过程即每次从无序表中取出第一个元素,将它插入到有序表中,使之成为新的 ...

  8. 插入排序算法java

    转自https://blog.csdn.net/jianyuerensheng/article/details/51254415 1.基本思想 直接插入排序的基本操作是将一个记录插入到已经排好的有序表 ...

  9. Java基础(47):插入排序的Java封装(含原理,可运行,哨兵位的理解见VisualGo上面的动态分析)

    直接插入排序(Straight Insertion Sorting)的基本思想:在要排序的一组数中,假设前面(n-1) [n>=2] 个数已经是排好顺序的,现在要把第n个数插到前面的有序数中,使 ...

随机推荐

  1. sqlserver2008事物处理---待续

    声明事物:begin tran 回滚事物:ROLLBACK TRAN 提交事物:commit tran(不写会隐式提交) 判断是否发生异常: 结束前: IF @@ERROR <> 0 BE ...

  2. sql拼接字符串

    update boc_loan_apply set birthday=concat(birthday,'-01');

  3. Pwdump v7.1

    提取windows系统密码  和 hash值

  4. java如何集成支付宝移动快捷支付功能

    项目需要,需要在客户端集成支付宝接口.第一次集成,过程还是挺简单的,不过由于支付宝官方文档写的不够清晰,也是走了一些弯路,下面把过程写出来分享给大家.就研究了一下:因为使用支付宝接口,就需要到支付宝官 ...

  5. Spring设置定时器配置

    corn表达式生成:http://www.pppet.net/ 1.注解方式 添加命名空间 xmlns:task="http://www.springframework.org/schema ...

  6. VM参数收集(部分)

    VM参数收集 -verbose:gc 输出虚拟机中GC的详细情况 -Xms20M Heap初始容量为 20M -Xmx20M Heap最大容量为 20M -XX:+HeapDumpOnOutOfMem ...

  7. sockaddr与sockaddr_in

    struct sockaddr { unsigned short sa_family;     char sa_data[14]; }; 此数据结构用做bind.connect.recvfrom.se ...

  8. Web 应用简单测试方案

    测试:一定要分阶段测试,先确定入队列成功,再测试队列的执行是否成功. 功能点: 1. 翻页2. 加精3. 置顶4. 帖子浏览量(PV)5. 发帖6. 回复7. 评论 8. crontab 脚本 @20 ...

  9. 搭建一个基于CentOS的可视化zookeeper管理工具zkUI实现对zk的可视化管理

    一. zookeeper 可视化工具   JMX => CLRProfile ZKUI => java写的一个可视化的web网站 github中下载 https://github.com/ ...

  10. C#动态编译引擎-CS-Script 简单使用

    Technorati 标记: cs-script 介绍可以参看  http://www.cnblogs.com/shanyou/p/3413585.html 还可以参看 这个  项目介绍 性能测试 c ...