快排必背模板(Java)| 分治 + 双指针 + 3 步口诀

以下是Java实现快速排序的代码,添加了便于快速记忆的注释和口诀:

代码实现(带注释)

java 复制代码
public class QuickSort {
    public void sort(int[] arr) {
        if (arr == null || arr.length == 0) return;
        quickSort(arr, 0, arr.length - 1);
    }

    private void quickSort(int[] arr, int left, int right) {
        if (left >= right) return; // 终止条件
        
        int pivotIndex = partition(arr, left, right); // 分区
        quickSort(arr, left, pivotIndex - 1);         // 递归左半部分
        quickSort(arr, pivotIndex + 1, right);        // 递归右半部分
    }

    private int partition(int[] arr, int left, int right) {
        int pivot = arr[right];  // 选择最右元素作为基准值
        int i = left - 1;        // 小于基准值的元素边界
        
        for (int j = left; j < right; j++) {
            if (arr[j] <= pivot) {
                i++;
                swap(arr, i, j); // 将小于等于基准值的元素交换到左边
            }
        }
        
        swap(arr, i + 1, right); // 将基准值放到正确位置
        return i + 1;            // 返回基准值的索引
    }

    private void swap(int[] arr, int i, int j) {
        int temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp;
    }
}

记忆口诀

css 复制代码
快排分三步,基准分区递归走
分区选最右,双指针来比大小
i指针标记小,j指针向前找
小于基准就交换,最后基准归位好

关键点记忆

  1. 核心思想:分治法(Divide and Conquer)
  2. 分区逻辑
    • 选择最右元素为基准值(pivot)
    • 使用双指针 iji 标记小于基准值的元素边界
  3. 递归过程
    • 左半部分:[left, pivotIndex-1]
    • 右半部分:[pivotIndex+1, right]
相关推荐
yyy(十一月限定版)3 分钟前
matlab矩阵的操作
算法·matlab·矩阵
努力学算法的蒟蒻20 分钟前
day58(1.9)——leetcode面试经典150
算法·leetcode·面试
txinyu的博客35 分钟前
map和unordered_map的性能对比
开发语言·数据结构·c++·算法·哈希算法·散列表
搞笑症患者1 小时前
压缩感知(Compressed Sensing, CS)
算法·最小二乘法·压缩感知·正交匹配追踪omp·迭代阈值it算法
im_AMBER1 小时前
Leetcode 101 对链表进行插入排序
数据结构·笔记·学习·算法·leetcode·排序算法
快手技术1 小时前
AAAI 2026|全面发力!快手斩获 3 篇 Oral,12 篇论文入选!
前端·后端·算法
颜酱1 小时前
前端算法必备:滑动窗口从入门到很熟练(最长/最短/计数三大类型)
前端·后端·算法
做科研的周师兄1 小时前
【MATLAB 实战】栅格数据 K-Means 聚类(分块处理版)—— 解决大数据内存溢出、运行卡顿问题
人工智能·算法·机器学习·matlab·kmeans·聚类
X在敲AI代码1 小时前
leetcodeD3
数据结构·算法
码农小韩1 小时前
基于Linux的C++学习——循环
linux·c语言·开发语言·c++·算法