排序算法---(三)

引言

紧接上次排序文章的希尔排序、简单选择排序,今天再来讲两种排序:快速排序、归并排序

快速排序

1.思路

(1)定义一个基准数值(暂且为数组的第一个元素),并定义 i 和 j 两个游标,指向数组的两端

(2)j 在数组最右端,向左移找比基准数值小的元素,找到后停止

(3)i 在数组最左端,向右移找比基准数值大的元素,找到后停止

(4)若 i 和 j 不相遇,交换各自指向的元素,重复直到 i 和 j 相遇

(5)相遇后,说明 i 和 j 共同指向的位置左边均小于基准数值,右边均大于基准数值,因此将基准数值和 i 或 j 指向的元素进行交换

(6)以基准数值为界,再对左右两个数组进行上述流程,直到拆分成一个元素为一组时停止

这里博主依旧手写一份过程,帮助大家理解(仅展示一轮):

2.关键点

第六步提到了拆分成左右两个数组,再次进行前五步的过程,说起来容易,要怎么实现呢?这就用到了递归,就是再次调用自身函数,因为前五步的流程都是一样的,只需要改变"数组"的left和 right 即可

3.代码

java 复制代码
public class QuickSort {
    public static void main(String[] args) {

        int[] arr = {3,2,1,5,4,6,7,8,9,10};

        quickSort(arr,0,arr.length-1);

        for(int i = 0;i<arr.length;i++){
            System.out.print(arr[i]+" ");
        }
    }
    public static void quickSort(int[] arr,int left,int right){
        if(left >= right){
            return;
        }

        //1.定义基准数值
        int base = arr[left];

        //2.定义出i和j;两个游标
        int i = left;
        int j = right;
        while(i<j){
            while(arr[j] >= base && i<j){
                j--;
            }
            while(arr[i] <= base && i<j){
                i++;
            }
            int temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }

        //相遇位置的数和基准数值交换
        arr[left] = arr[i];
        arr[i] = base;

        quickSort(arr,left,i-1);
        quickSort(arr,i+1,right);
    }
}

归并排序

1.思路

先拆分再合并

拆分:把每个元素都拆开拆分,还是像快速排序一样调用自身实现拆分,

合并:用临时空间 temp 来存储每次合并的结果,并且定义一个指针 index 来将合并的元素依次放入临时数组 temp ,在合并过程需要进行大小比较:对合并的两个数组,分别有两个指针 s1、s2 来指向对应数组的第一个元素,将两个指针 s1 、s1 指向的元素进行比较,小的放在index 指向的临时数组的位置,以此类推,这样就实现了两个数组的合并(有序的放入临时空间)

这里博主手写一份过程,来帮大家理解:

2.代码

java 复制代码
public class MergeSort {
    public static void main(String[] args) {

        int[] arr = {3,2,1,5,4,6,7,8,9,10};

        sort(arr,0,arr.length-1);

        for(int i = 0;i<arr.length;i++){
            System.out.print(arr[i]+" ");
        }
    }
    public static  void sort(int[] arr,int left,int right){
        if(left == right){
            return;
        }
        int mid = (left+right)/2;
        sort(arr,left,mid);
        sort(arr,mid+1,right);
        //合并
        merge(arr,left,mid,right);
    }
    public static void merge(int[] arr,int left,int mid,int right){
        int temp[] = new int[right-left+1];
        int s1 = left;
        int s2 = mid+1;
        int index = 0;
        while(s1<=mid && s2<=right){
            if(arr[s1]<arr[s2]){
                temp[index] = arr[s1];
                s1++;  index++;
            }else{
                temp[index] = arr[s2];
                s2++; index++;
            }
        }
        while(s1<=mid){
            temp[index] = arr[s1];
            s1++;  index++;
        }
        while(s2<=right){
            temp[index] = arr[s2];
            s2++; index++;
        }

        for(int j = 0;j<temp.length;j++){
            arr[j+left] = temp[j];
        }
    }
}
相关推荐
njidf2 小时前
C++中的观察者模式
开发语言·c++·算法
2301_822782822 小时前
C语言数组通关攻略!从一维到字符数组,零基础也能轻松掌握
c语言·算法·数组·编程基础·避坑技巧
zhugby2 小时前
标号法原理
算法
努力学习的小廉3 小时前
我爱学算法之——动态规划(一)
算法·动态规划
篮l球场3 小时前
前 K 个高频元素
数据结构·算法·leetcode
汉克老师3 小时前
GESP5级C++考试语法知识(十一、递归算法(一))
c++·算法·记忆化搜索·递归算法·递归优化
历程里程碑3 小时前
Proto3 三大高级类型:Any、Oneof、Map 灵活解决复杂业务场景
java·大数据·开发语言·数据结构·elasticsearch·链表·搜索引擎
qq_148115373 小时前
C++网络编程(Boost.Asio)
开发语言·c++·算法
2301_804215413 小时前
内存映射文件高级用法
开发语言·c++·算法