zoukankan      html  css  js  c++  java
  • 插入排序 思想 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

    往前走,别回头!
  • 相关阅读:
    学习asp.net比较完整的流程
    时间的获取和转换,C#和Sql
    学习一种新编程语言要做的10几个练习
    分布式网络管理优点总结
    点对点网络大解析
    如何阅读他人的程序代码
    WebConfig
    正则表达式30分钟入门教程
    程序员遇到BUG的解释
    在T-SQL语句中访问远程数据库(openrowset/opendatasource/openquery)
  • 原文地址:https://www.cnblogs.com/dev1ce/p/10598454.html
Copyright © 2011-2022 走看看