排序算法-快速排序

快速排序

快速排序原理

快速排序(Quick Sort)是一种基于分治思想的排序算法,通过选择一个基准值,将数组分为两个子数组,一个子数组中的元素都比基准值小,另一个子数组中的元素都比基准值大,然后递归地对子数组进行排序,最终得到一个有序数组。

public class QuickSortDemo {
    int[] numArrays = {4,3,6,2,9,1,7,3,2,9,6,10};

    /**
     *
     * 快速排序的入门方法
     * @param arr 需要排序的数组
     * @param left 左边界
     * @param right 右边界
     */
    public static void quickSort(int[] arr, int left, int right) {
        //如果左边界小于右边界
        if (left < right) {
            // 获取枢轴元素的下标
            int pivotIndex = partition(arr, left, right);
            // 对枢轴元素左边的子数组进行快速排序
            quickSort(arr, left, pivotIndex - 1);
            // 对枢轴元素右边的子数组进行快速排序
            quickSort(arr, pivotIndex + 1, right);
        }
    }

    /**
     * 选取基准元素,并将数组划分为两个部分
     * @param arr 需要排序的数组
     * @param left 左边界
     * @param right 右边界
     * @return 返回基准元素的下标
     */
    private static int partition(int[] arr, int left, int right) {
        //选择最左侧的元素作为枢轴元素
        int pivot = arr[right];
        //指向左边界的前一个元素
        int i = left - 1;
        //遍历left,right区间的内的元素
        for (int j = left; j < right; j++) {
            //如果当前元素小于枢轴元素
            if (arr[j] < pivot) {
                //i向右移动一位
                i++;
                //元素调换arr[i]与arr[j]的位置
                int temp = arr[i];
                arr[i] = arr[j];
                arr[j] = temp;
            }
        }
        //交换arr[i + 1]与arr[right]的位置
        int temp = arr[i + 1];
        arr[i + 1] = arr[right];
        arr[right] = temp;
        return i + 1;
    }

    @Test
    public void test(){
        this.quickSort(numArrays,0,numArrays.length-1);
        System.out.println(Arrays.toString(numArrays));
    }
}

在这里插入图片描述

相关推荐

  1. 排序算法——快速排序

    2024-04-21 16:28:05       42 阅读
  2. 排序算法——快速排序

    2024-04-21 16:28:05       43 阅读
  3. 排序算法-快速排序

    2024-04-21 16:28:05       46 阅读
  4. 排序算法——快速排序

    2024-04-21 16:28:05       16 阅读

最近更新

  1. shell脚本实现mysql 数据库备份

    2024-04-21 16:28:05       0 阅读
  2. 数据结构第11节: B树

    2024-04-21 16:28:05       0 阅读
  3. Spring Boot与RSocket的集成

    2024-04-21 16:28:05       0 阅读
  4. 责任链模式

    2024-04-21 16:28:05       0 阅读
  5. docker run/build Dockerfile 修改及完善

    2024-04-21 16:28:05       1 阅读

热门阅读

  1. 数据结构递归算法总结

    2024-04-21 16:28:05       15 阅读
  2. VSCode和CMake实现C/C++开发

    2024-04-21 16:28:05       17 阅读
  3. 小记一篇 vuecli4项目 打包内存溢出问题

    2024-04-21 16:28:05       13 阅读
  4. 线上出现问题后如何排查呢

    2024-04-21 16:28:05       13 阅读
  5. C及C++标准与QT版本介绍

    2024-04-21 16:28:05       14 阅读
  6. Qt : 如何解决重载引起的歧义

    2024-04-21 16:28:05       15 阅读