直接插入排序算法

 基本思想:

  把n个待排序的元素看成一个有序表和一个无序表,开始时有序表中只有一个元素,无序表中有n-1个元素;排序过程即每次从无序表中取出第一个元素,将它插入到有序表中,使之成为新的有序表,重复n-1次完成整个排序过程。

 实例:

  0.初始状态 3,1,5,7,2,4,9,6(共8个数)

     有序表:3;无序表:1,5,7,2,4,9,6

  1.第一次循环,从无序表中取出第一个数 1,把它插入到有序表中,使新的数列依旧有序

     有序表:1,3;无序表:5,7,2,4,9,6

  2.第二次循环,从无序表中取出第一个数 5,把它插入到有序表中,使新的数列依旧有序

     有序表:1,3,5;无序表:7,2,4,9,6

  3.第三次循环,从无序表中取出第一个数 7,把它插入到有序表中,使新的数列依旧有序

     有序表:1,3,5,7;无序表:2,4,9,6

  4.第四次循环,从无序表中取出第一个数 2,把它插入到有序表中,使新的数列依旧有序

     有序表:1,2,3,5,7;无序表:4,9,6

  5.第五次循环,从无序表中取出第一个数 4,把它插入到有序表中,使新的数列依旧有序

     有序表:1,2,3,4,5,7;无序表:9,6

  6.第六次循环,从无序表中取出第一个数 9,把它插入到有序表中,使新的数列依旧有序

     有序表:1,2,3,4,5,7,9;无序表:6

  7.第七次循环,从无序表中取出第一个数 6,把它插入到有序表中,使新的数列依旧有序

     有序表:1,2,3,4,5,6,7,9;无序表:(空)

 Java实现:

  1. package sort;
    /**
  2. * 直接插入排序 的实现
  3. * 稳定算法
  4. * @author 那一季的银杏叶
  5. *
  6. */
  7. public class InsertSort {
  8. public static void main(String[] args) {
  9. // TODO Auto-generated method stub
  10. int a[] = {3,1,5,7,2,4,9,6};
  11. new InsertSort().insertSort(a);
  12. }
  13. /**
  14. * 直接插入排序算法的实现
  15. * @param a
  16. */
  17. private void insertSort(int[] a) {
  18. // TODO Auto-generated method stub
  19. System.out.println("———————————————————直接插入排序算法—————————————————————");
  20. int n = a.length;
  21. int i,j;
  22. for(i=1;i<n;i++){
  23. /**
  24. * temp为本次循环待插入有序列表中的数
  25. */
  26. int temp = a[i];
  27. /**
  28. * 寻找temp插入有序列表的正确位置
  29. */
  30. for(j=i-1;j>=0 && a[j]>temp;j--){
  31. /**
  32. * 元素后移,为插入temp做准备
  33. */
  34. a[j+1] = a[j];
  35. }
  36. /**
  37. * 插入temp
  38. */
  39. a[j+1] = temp;
  40. print(a,n,i);
  41. }
  42. printResult(a,n);
  43. }
  44. /**
  45. * 打印排序的最终结果
  46. * @param a
  47. * @param n
  48. */
  49. private void printResult(int[] a, int n){
  50. System.out.print("最终排序结果:");
  51. for(int j=0;j<n;j++){
  52. System.out.print(" "+a[j]);
  53. }
  54. System.out.println();
  55. }
  56. /**
  57. * 打印排序的每次循环的结果
  58. * @param a
  59. * @param n
  60. * @param i
  61. */
  62. private void print(int[] a, int n, int i) {
  63. // TODO Auto-generated method stub
  64. System.out.print("第"+i+"次:");
  65. for(int j=0;j<n;j++){
  66. System.out.print(" "+a[j]);
  67. }
  68. System.out.println();
  69. }
  70. }

 运行结果展示:

 

  (本文仅供学习交流,如有更好的思路,欢迎留下意见供大家探讨学习~) 

排序系列 之 直接插入排序算法 —— Java实现的更多相关文章

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

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

  2. 排序算法系列:插入排序算法JAVA版(靠谱、清晰、真实、可用、不罗嗦版)

    在网上搜索算法的博客,发现一个比较悲剧的现象非常普遍: 原理讲不清,混乱 啰嗦 图和文对不上 不可用,甚至代码还出错 我总结一个清晰不罗嗦版: 原理: 和选择排序类似的是也分成“已排序”部分,和“未排 ...

  3. 插入排序算法 Java实现

    插入排序算法是算法排序中的一种: 该算法是假设已有序列是有序序列,从首元素(首元素为单个元素,肯定是有序的...)开始分析,对其他元素的位置进行有序的确定: 以算法为例: public class I ...

  4. 【排序算法】快速插入排序算法 Java实现

    基本思想 每次将一个待排序的记录,按其关键字大小插入到前面已经排好序的子序列中的适当位置,直到全部插入完成. 设数组为a[0...n-1] 初始时,a[0]自成一个有序区,无序区为a[1...n-1] ...

  5. 插入排序算法Java实现

    一. 算法描述 插入即表示将一个新的数据插入到一个有序数组中,并继续保持有序.例如有一个长度为N的无序数组,进行N-1次的插入即能完成排序:第一次,数组第1个数认为是有序的数组,将数组第二个元素插入仅 ...

  6. 插入排序算法java

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

  7. 两种插入排序算法java实现

    两种方法都编译运行通过,可以当做排序类直接使用. 折半插入排序: public class Sort1 { public static void main(String[] args) { Inser ...

  8. 排序算法Java代码实现(三)—— 插入排序 和 希尔排序

    因为希尔排序的核心思想是插入排序,所以本篇将两篇排序一起记录 本篇内容: 插入排序 希尔排序 (一)插入排序 算法思想: 把n个待排序的元素看成一个有序表和一个无序表,开始时有序表中只有一个元素,无序 ...

  9. 插入排序算法--直接插入算法,折半排序算法,希尔排序算法(C#实现)

    插入排序算法主要分为:直接插入算法,折半排序算法(二分插入算法),希尔排序算法,后两种是直接插入算法的改良.因此直接插入算法是基础,这里先进行直接插入算法的分析与编码. 直接插入算法的排序思想:假设有 ...

随机推荐

  1. JAVA开发错误总结(仅记录遇到的错误---后续不断更新......)

    =======华丽分割线(工具总结)===================== 1:Maven项目中junit测试找不到主类的问题 Class not found com.test.utils.tes ...

  2. InventSumDelta表的作用

    https://groups.google.com/forum/#!topic/microsoft.public.axapta.programming/rRfbJo9M0dk The purpose ...

  3. MySQL之存储引擎MyISAM/InnoDB高并发优化经验

    https://www.centos.bz/2011/09/mysql-myisam-innodb-optimization-experience/

  4. Asp.net MVC3表格共用分页功能

    在建立的mvc3项目中,在Razor(CSHTML)视图引擎下,数据会在表格中自动的生成,但分页没有好的控件实现,这里我们开发了设计了一个分页的模板,适合于没有数据提交和有数据提交的分页的分页. 第一 ...

  5. 学习iOS【3】数组、词典和集合

    一.数组 1.不可变数组NSArray arrayWithObjects:使用一组对象作为元素创建不可变数组,注意数组的最后一个值需要指定为nil,用来表示参数的结束,但是nil并不会存储在数组中. ...

  6. 我们应当怎样学习HTML和CSS

    目标读者:web前端小白.大神请绕路 学习一门新技术,应当找一本经典入门书,在两三天之内快速翻阅完毕,了解其概貌. 然后再制定一个学习路线图(这个路线图绝大多数情况下非书本目录的顺序),接着遵循学习路 ...

  7. YCSB-压测

    安装 wget http://download.oracle.com/otn-pub/java/jdk/7u40-b43/jdk-7u40-linux-x64.rpm #注意此处到官网下载后上传,需要 ...

  8. Spring整合HBase

    Spring整合HBase Spring HBase SHDP § 系统环境 § 配置HBase运行环境 § 配置Hadoop § 配置HBase § 启动Hadoop和HBase § 创建Maven ...

  9. 使用 AngularJS 和 Electron 构建桌面应用

    GitHub 的 Electron 框架(以前叫做 Atom Shell)允许你使用 HTML, CSS 和 JavaScript 编写跨平台的桌面应用.它是io.js 运行时的衍生,专注于桌面应用而 ...

  10. shell 转义字符的写法

    在链接中,往往会遇到含有‘&'字符的情形,需要转义方能使用. 以下是它的写法样例,错误的写法勿要再犯!! 链接样例: http://my.example.cn/show/details/htd ...