排序算法-快速排序

快速排序

快速排序原理

快速排序(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));
    }
}
相关推荐
蒋星熠7 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
小欣加油8 小时前
leetcode 面试题01.02判定是否互为字符重排
数据结构·c++·算法·leetcode·职场和发展
3Cloudream8 小时前
LeetCode 003. 无重复字符的最长子串 - 滑动窗口与哈希表详解
算法·leetcode·字符串·双指针·滑动窗口·哈希表·中等
王璐WL8 小时前
【c++】c++第一课:命名空间
数据结构·c++·算法
空白到白9 小时前
机器学习-聚类
人工智能·算法·机器学习·聚类
索迪迈科技9 小时前
java后端工程师进修ing(研一版 || day40)
java·开发语言·学习·算法
zzzsde9 小时前
【数据结构】队列
数据结构·算法
芒克芒克9 小时前
LeetCode 面试经典 150 题:删除有序数组中的重复项(双指针思想解法详解)
算法
青 .9 小时前
数据结构---二叉搜索树的实现
c语言·网络·数据结构·算法·链表
MChine慕青10 小时前
顺序表与单链表:核心原理与实战应用
linux·c语言·开发语言·数据结构·c++·算法·链表