2018-05-02 排序算法学习

排序算法

冒泡排序

实现思路:

  • 两两比较相邻的关键码,如果反序则交换,直到没有反序的记录

快速排序

实现思路:

  • 快速排序算是对冒泡排序算法的改进,从记录序列的两端向中间进行

两者的区别


由于冒泡排序是对相邻的数据进行两两比较,元素的移动次数和比较次数都比较多,而快速排序是从记录序列的两端向中间进行,所以在元素的移动次数和比较次数上都减少了


冒泡排序使用两层循环嵌套,具体代码省略
具体实现快速排序算法:

public static void sortCore(int[] array,int startIndex,int endIndex) {
        if(startIndex>=endIndex) {
            return;
        }
        
        int boundary=boundary(array,startIndex,endIndex);//选择划分的Index值
        //递归调用,对数组两部分排序
        sortCore(array,startIndex,boundary-1);
        sortCore(array,boundary+1,endIndex);
    }

    private static int boundary(int[] array, int startIndex, int endIndex) {
        int standard=array[startIndex];//定义标准,一般取首值、中值或末值
        int leftIndex=startIndex;//左指针
        int rightIndex=endIndex;//右指针
        while(leftIndex=standard) {
                rightIndex--;//找出右半部分小于标准的Index值
            }
            array[leftIndex]=array[rightIndex];//把小于的值赋值到左半部分
            while(leftIndex

选择排序

  • 每趟排序在当前待排序序列中选出关键码最小的记录,添加到有序序列中
  • 特点是记录的移动次数少
    inti,j;
    for(i=0;i

几种排序算法的比较和选择

  • 选取排序方法需要考虑的因素:待排序元素数量n、元素分布情况、元素信息量大小、使用的语言工具

小结

  1. 若n较小(n <= 50),则可以采用直接插入排序或直接选择排序。由于直接插入排序所需的记录移动操作较直接选择排序多,因而当记录本身信息量较大时,用直接选择排序较好。
  2. 若文件的初始状态已按关键字基本有序,则选用直接插入或冒泡排序为宜。
  3. 若n较大,则应采用时间复杂度为O(nlog2n)的排序方法:快速排序、堆排序或归并排序。快速排序是目前基于比较的内部排序法中被认为是最好的方法。
  4. 在基于比较排序方法中,每次比较两个关键字的大小之后,仅仅出现两种可能的转移,因此可以用一棵二叉树来描述比较判定过程,由此可以证明:当文件的n个关键字随机分布时,任何借助于"比较"的排序算法,至少需要O(nlog2n)的时间。
  5. 当记录本身信息量较大时,为避免耗费大量时间移动记录,可以用链表作为存储结构。

你可能感兴趣的:(2018-05-02 排序算法学习)