直接插入排序之Java实现

一、方法一

 package cn.com.zfc.lesson21.sort;

 import java.util.Arrays;

 /**
*
* @title InsertSort
* @describe 插入排序
* @author 张富昌
* @date 2016年10月1日下午5:12:41
*/
public class InsertSort_1 {
// 直接插入排序由 N-1 趟排序组成。
// 基本思想:将第一个元素看成一个有序子序列,再依次从第二个记录起诸葛插入到这个有序的子序列中。
// 一般地,将 elem[i] 插入到由 elem[0] ~ elem[i-1] 构成的有序子序列中
// 时间复杂度:O(n) ~ O(n^2) public static void main(String[] args) {
// 声明整型数组
int[] array = new int[10];
// 使用循环和随机数初始化数组
for (int i = 0; i < array.length; i++) {
array[i] = (int) Math.round(Math.random() * 100);
}
System.out.println("原始数组为:");
System.out.println(Arrays.toString(array));
System.out.println("--------------------------------------");
array = insertSort(array);
System.out.println("--------------------------------------");
System.out.println("排序后的数组为:");
System.out.println(Arrays.toString(array));
} /**
*
* 功能:插入排序的基本思想是,将元素逐个添加到已经排序好的数组中去,同时要求,插入的元素必须在正确的位置,这样原来排序好的数组是仍然有序的。
*
* 参数:int[] array
*
* 返回类型:int[]
*/
public static int[] insertSort(int[] array) {
// 使用临时数组,替代原始数组
int[] arr = array;
// 临时变量
int temp;
for (int i = 1; i < arr.length; i++) {
System.out.println("第 " + i + "趟");
for (int j = i; j >= 1; j--) {
// 较小的数排在前面
if (arr[j - 1] > arr[j]) {
temp = arr[j];
arr[j] = arr[j - 1];
arr[j - 1] = temp;
} else {
break;
}
}
System.out.println(Arrays.toString(arr));
}
return arr;
}
}

 运行结果:

二、方法二

 package cn.com.zfc.lesson21.sort;

 import java.util.Arrays;

 /**
*
* @title InsertSort
* @describe 插入排序
* @author 张富昌
* @date 2016年10月1日下午5:12:41
*/
public class InsertSort_2 {
// 直接插入排序由 N-1 趟排序组成。
// 基本思想:将第一个元素看成一个有序子序列,再依次从第二个记录起诸葛插入到这个有序的子序列中。
// 一般地,将 elem[i] 插入到由 elem[0] ~ elem[i-1] 构成的有序子序列中
// 时间复杂度:O(n) ~ O(n^2) public static void main(String[] args) {
// 声明整型数组
int[] array = new int[10];
// 使用循环和随机数初始化数组
for (int i = 0; i < array.length; i++) {
array[i] = (int) Math.round(Math.random() * 100);
}
System.out.println(Arrays.toString(array));
System.out.println("--------------------------------------");
array = insertSort(array);
System.out.println("--------------------------------------");
System.out.println("排序后的数组为:");
System.out.println(Arrays.toString(array));
} /**
*
* 功能:插入排序的基本思想是,将元素逐个添加到已经排序好的数组中去,同时要求,插入的元素必须在正确的位置,这样原来排序好的数组是仍然有序的。
*
* 参数:int[] array
*
* 返回类型:int[]
*/
public static int[] insertSort(int[] array) {
// 使用临时数组,替代原始数组
int[] arr = array;
int j, temp;
for (int i = 1; i < arr.length; i++) {
System.out.println("第 " + (i + 1) + "趟");
if (arr[i - 1] > arr[i]) {
temp = arr[i];
for (j = i - 1; j >= 0 && arr[j] > temp; j--) {
arr[j + 1] = arr[j];
}
arr[j + 1] = temp;
}
System.out.println(Arrays.toString(arr));
}
return arr;
}
}

运行结果:

最新文章

  1. java中的成员变量和局部变量区别
  2. c 终端控制
  3. 《JAVA编程那点事儿》读书笔记(二)——类和对象
  4. DataInputStream和DataOutputStream使用方法细节探讨
  5. SpringUtil
  6. hash --C++
  7. Javascript 探路
  8. 关于Html无宽度居中
  9. JSP自定义简单标签入门之带有属性
  10. Lesson 25 Do the English speak English?
  11. 【NET CORE微服务一条龙应用】第三章 认证授权与动态权限配置
  12. noip2016海港
  13. C# 高级编程9 介绍篇
  14. Spring Boot中使用Websocket搭建即时聊天系统
  15. 模糊测试之AVI文件分析
  16. 20155234 2016-2017-2 《Java程序设计》第7周学习总结
  17. CF448C Painting Fence
  18. iOS 开发系列:CoreData Object 变成 Fault 的一种方式
  19. 微信小游戏 小程序与小游戏获取用户信息接口调整 wx.createUserInfoButton
  20. 爬虫之JSON案例

热门文章

  1. plsql链接数据库配置
  2. 存储过程简单Demo
  3. 【FCS NOI2018】福建省冬摸鱼笔记 day6【FJOI 2018】福建省选混分滚蛋记 day1
  4. 十二、springboot之web开发之静态资源处理
  5. FM的推导原理--推荐系统
  6. 使用gradle编译安卓APK
  7. HDU 1054 Strategic Game(最小路径覆盖)
  8. Luogu P4894 【GodFly求解法向量】
  9. hdu 3537 翻硬币 每次能翻1个 或2个 或3个
  10. hdu 4559 涂色游戏(SG)