算法篇:Java实现九种排序算法1:插入排序之后直接插入排序

createh52个月前 (03-05)技术教程27

一、插入排序

思想:每步将一个待排序的记录,按其顺序码大小插入到前面已经排序的字序列的合适位置,直到全部插入排序完为止。

关键问题:在前面已经排好序的序列中找到合适的插入位置。

方法:直接插入排序、二分插入排序、希尔排序

二、直接插入排序

基本思想:每步将一个待排序的记录,按其顺序码大小插入到前面已经排序的字序列的合适位置(从后向前找到合适位置后),直到全部插入排序完为止。

java实现

public class ZhiJieChaRu {
    /**
     * 直接插入排序第一版
     * @param a
     * @return
     */
    public static int[] sort1(int[] a) {
        //假设第一个记录为已经待排序好的记录,那么要比较a.length-1个记录,所以外层循环是a.length-1次 
        //这里可以直接i=1从第二位开始处理也一样
        for(int i=1;i=0;j--) {
                //如果当前待排序的数比这一个排序的数大,则跳出循环,否则交换位置
                if(a[j+1]>a[j]) {
                    break;
                }else {
                        //这种每次比较后都马上移动,每次都定义临时变量,我们其实可以找到位置,最后再出入一次即可
                        int temp = a[j+1];
                        a[j+1]=a[j];
                        a[j]=temp;
                    }
                }
            }
            return a;
    }

    /**
     * 插入排序改进版,找到位置最后才插入
     * @param a
     * @return
     */
    public static int[] sort2(int[] a) {
        //假设第一个记录为已经待排序好的记录,那么要比较a.length-1个记录,所以外层循环是a.length-1次 
        //这里可以直接i=1从第二位开始处理也一样
        for(int i=1;i=0;j--) {
                //如果当前待排序的数比这一个排序的数大,则跳出循环,否则交换位置
                if(temp>a[j]) {
                    break;
                }else {
                    //把当前记录往后面移动一位
                    a[j+1]=a[j];
                }
            }
            a[j+1]=temp;
        }
            return a;
    }
    public static void main(String[] args) {
        int[] a = {49,38,65,97,76,13,27,49,78,34,12,64,1};
        System.out.print("排序之前:");
        for (int i = 0; i < a.length; i++) {
            System.out.print(a[i]+" ");
        }
        System.out.println();
        System.out.print("sort1:");
        int[] a1 = sort1(a);
        int[] a2 = sort2(a);
        for (int i = 0; i < a1.length; i++) {
            System.out.print(a1[i]+" ");
        }
        System.out.println();
        System.out.print("sort2:");
        for (int i = 0; i < a2.length; i++) {
            System.out.print(a2[i]+" ");
        }
    }
}

上面有两种实现方法,第二种sort2比较好,不用每次都新建temp;

相关文章

Java选择排序法

假设当前存在一个 int 类型的数组 number,该数组中的元素依次是 13、15、 24、99、4 和 1。如果使用冒泡排序进行两两相邻比较,第 一趟排序后的结果如下:  13、15、24、4、1...

java实现10种排序算法

1.冒泡排序(Bubble Sort)import java.util.Arrays;//冒泡排序public class BubbleSort_01 {public static void main...

6.Java中ArrayList进行排序总结

文章目录前言1.基础类型的集合排序:2.实体类的集合排序传统:3.Java8使用流式的排序:结尾前言ArrayList是最常见最频繁我们java编程当中使用的集合类,往往进行集合操作的时候会进行排序操...

Java算法总结之冒泡排序(详解)

程序代码园发文地址:Java算法总结之冒泡排序(详解)-程序代码园冒泡排序(默认升序)算法原理:1、比较相邻的元素。如果第一个比第二个大,就交换他们两个。 2、对每一对相邻元素做同样的工作,从开始第一...

深圳尚学堂Java培训:排序方法小结-冒泡排序

作为一个初学者,排序算法可能是接触到的最早的逻辑实例了,而且这些个逻辑还确实有点伤脑筋,那我就将一些经典的排序算法记下来吧,以后也可以来瞧瞧。一、冒泡排序最直接、最好理解、初学者最容易想到的排序算法!...