排序算法-快速排序

快速排序

快速排序原理

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

java 复制代码
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));
    }
}
相关推荐
郝学胜-神的一滴21 分钟前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
颜酱2 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
m0_736919102 小时前
C++代码风格检查工具
开发语言·c++·算法
yugi9878382 小时前
基于MATLAB强化学习的单智能体与多智能体路径规划算法
算法·matlab
DuHz2 小时前
超宽带脉冲无线电(Ultra Wideband Impulse Radio, UWB)简介
论文阅读·算法·汽车·信息与通信·信号处理
Polaris北极星少女3 小时前
TRSV优化2
算法
代码游侠3 小时前
C语言核心概念复习——网络协议与TCP/IP
linux·运维·服务器·网络·算法
2301_763472464 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
abluckyboy4 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法
园小异4 小时前
2026年技术面试完全指南:从算法到系统设计的实战突破
算法·面试·职场和发展