插入排序 思想 JAVA实现
已知一个数组 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实现的更多相关文章
- java 用插入排序思想,对不规则数组排序。
知道插入排序后,无意中发现,用插入排序思想,对不规则数组排序的排序 发现和许多大神写的不一样,大神写的简洁多了.--------
- 直接插入排序之Java实现
直接插入排序之Java实现 一.方法一 package cn.com.zfc.lesson21.sort; import java.util.Arrays; /** * * @title Insert ...
- 排序算法入门之插入排序(java实现)
插入排序思想:相当于插入元素,对于第i个元素,i之前的元素已经是有序的了,这时候将第i个元素依次与前面元素比较,插入合适的位置.
- 基本算法思想Java实现的详细代码
基本算法思想Java实现的详细代码 算法是一个程序的灵魂,一个好的算法往往可以化繁为简,高效的求解问题.在程序设计中算法是独立于语言的,无论使用哪一种语言都可以使用这些算法,本文笔者将以Java语言为 ...
- 33.JAVA编程思想——JAVA IO File类
33.JAVA编程思想--JAVA IO File类 RandomAccessFile用于包括了已知长度记录的文件.以便我们能用 seek()从一条记录移至还有一条:然后读取或改动那些记录. 各记录的 ...
- 排序系列 之 折半插入排序算法 —— Java实现
基本思想: 折半插入算法是对直接插入排序算法的改进,排序原理同直接插入算法: 把n个待排序的元素看成一个有序表和一个无序表,开始时有序表中只有一个元素,无序表中有n-1个元素:排序过程即每次从无序表中 ...
- 排序系列 之 直接插入排序算法 —— Java实现
直接插入排序算法 基本思想: 把n个待排序的元素看成一个有序表和一个无序表,开始时有序表中只有一个元素,无序表中有n-1个元素:排序过程即每次从无序表中取出第一个元素,将它插入到有序表中,使之成为新的 ...
- 插入排序算法java
转自https://blog.csdn.net/jianyuerensheng/article/details/51254415 1.基本思想 直接插入排序的基本操作是将一个记录插入到已经排好的有序表 ...
- Java基础(47):插入排序的Java封装(含原理,可运行,哨兵位的理解见VisualGo上面的动态分析)
直接插入排序(Straight Insertion Sorting)的基本思想:在要排序的一组数中,假设前面(n-1) [n>=2] 个数已经是排好顺序的,现在要把第n个数插到前面的有序数中,使 ...
随机推荐
- sqlserver2008事物处理---待续
声明事物:begin tran 回滚事物:ROLLBACK TRAN 提交事物:commit tran(不写会隐式提交) 判断是否发生异常: 结束前: IF @@ERROR <> 0 BE ...
- sql拼接字符串
update boc_loan_apply set birthday=concat(birthday,'-01');
- Pwdump v7.1
提取windows系统密码 和 hash值
- java如何集成支付宝移动快捷支付功能
项目需要,需要在客户端集成支付宝接口.第一次集成,过程还是挺简单的,不过由于支付宝官方文档写的不够清晰,也是走了一些弯路,下面把过程写出来分享给大家.就研究了一下:因为使用支付宝接口,就需要到支付宝官 ...
- Spring设置定时器配置
corn表达式生成:http://www.pppet.net/ 1.注解方式 添加命名空间 xmlns:task="http://www.springframework.org/schema ...
- VM参数收集(部分)
VM参数收集 -verbose:gc 输出虚拟机中GC的详细情况 -Xms20M Heap初始容量为 20M -Xmx20M Heap最大容量为 20M -XX:+HeapDumpOnOutOfMem ...
- sockaddr与sockaddr_in
struct sockaddr { unsigned short sa_family; char sa_data[14]; }; 此数据结构用做bind.connect.recvfrom.se ...
- Web 应用简单测试方案
测试:一定要分阶段测试,先确定入队列成功,再测试队列的执行是否成功. 功能点: 1. 翻页2. 加精3. 置顶4. 帖子浏览量(PV)5. 发帖6. 回复7. 评论 8. crontab 脚本 @20 ...
- 搭建一个基于CentOS的可视化zookeeper管理工具zkUI实现对zk的可视化管理
一. zookeeper 可视化工具 JMX => CLRProfile ZKUI => java写的一个可视化的web网站 github中下载 https://github.com/ ...
- C#动态编译引擎-CS-Script 简单使用
Technorati 标记: cs-script 介绍可以参看 http://www.cnblogs.com/shanyou/p/3413585.html 还可以参看 这个 项目介绍 性能测试 c ...