力扣215.返回数组中第K个最大元素

复制代码
class Solution {
    // 寻找数组中第k大的元素
    public int findKthLargest(int[] nums, int k) {
        // 初始化堆的大小为数组长度
        int heapSize = nums.length;
        // 构建最大堆
        buildMaxHeap(nums, heapSize);
        // 从最后一个元素开始,逐个将堆顶元素(最大值)与当前元素交换,然后重新调整堆
        for (int i = nums.length - 1; i >= nums.length - k + 1; --i) {
            swap(nums, 0, i); // 交换堆顶元素与当前元素
            --heapSize; // 减小堆的大小
            maxHeapify(nums, 0, heapSize); // 重新调整堆
        }
        return nums[0]; // 返回堆顶元素,即第k大的元素
    }

    // 构建最大堆
    public void buildMaxHeap(int[] a, int heapSize) {
        // 从最后一个非叶子节点开始向上调整堆
        for (int i = heapSize / 2; i >= 0; --i) {
            maxHeapify(a, i, heapSize);
        }
    }

    // 调整堆,使其满足最大堆的性质
    public void maxHeapify(int[] a, int i, int heapSize) {
        // 计算左右子节点的索引
        int l = i * 2 + 1, r = i * 2 + 2, largest = i;
        // 如果左子节点存在且大于当前节点,则更新最大节点索引
        if (l < heapSize && a[l] > a[largest]) {
            largest = l;
        }
        // 如果右子节点存在且大于当前最大节点,则更新最大节点索引
        if (r < heapSize && a[r] > a[largest]) {
            largest = r;
        }
        // 如果最大节点不是当前节点,交换它们并继续调整堆
        if (largest != i) {
            swap(a, i, largest);
            maxHeapify(a, largest, heapSize);
        }
    }

    // 交换数组中的两个元素
    public void swap(int[] a, int i, int j) {
        int temp = a[i];
        a[i] = a[j];
        a[j] = temp;
    }
}
复制代码
public class Solution {
    // 快速选择算法,用于查找第 k 大的元素
    private int quickSelect(List<Integer> nums, int k) {
        // 随机选择基准数
        Random rand = new Random();
        int pivot = nums.get(rand.nextInt(nums.size()));
        // 将大于、小于、等于 pivot 的元素划分至 big, small, equal 中
        List<Integer> big = new ArrayList<>();
        List<Integer> equal = new ArrayList<>();
        List<Integer> small = new ArrayList<>();
        for (int num : nums) {
            if (num > pivot)
                big.add(num); // 大于基准数的元素放入 big 列表
            else if (num < pivot)
                small.add(num); // 小于基准数的元素放入 small 列表
            else
                equal.add(num); // 等于基准数的元素放入 equal 列表
        }
        // 第 k 大元素在 big 中,递归划分
        if (k <= big.size())
            return quickSelect(big, k);
        // 第 k 大元素在 small 中,递归划分
        if (nums.size() - small.size() < k)
            return quickSelect(small, k - nums.size() + small.size());
        // 第 k 大元素在 equal 中,直接返回 pivot
        return pivot;
    }

    // 主函数,用于调用快速选择算法
    public int findKthLargest(int[] nums, int k) {
        List<Integer> numList = new ArrayList<>();
        for (int num : nums) {
            numList.add(num); // 将数组转换为列表
        }
        return quickSelect(numList, k); // 调用快速选择算法查找第 k 大的元素
    }
}
相关推荐
anlogic36 分钟前
Java基础 8.18
java·开发语言
胡萝卜3.01 小时前
数据结构初阶:排序算法(一)插入排序、选择排序
数据结构·笔记·学习·算法·排序算法·学习方法
地平线开发者1 小时前
LLM 中 token 简介与 bert 实操解读
算法·自动驾驶
练习时长一年1 小时前
AopAutoConfiguration源码阅读
java·spring boot·intellij-idea
scx201310042 小时前
20250814 最小生成树和重构树总结
c++·算法·最小生成树·重构树
阿巴~阿巴~2 小时前
冒泡排序算法
c语言·开发语言·算法·排序算法
散1122 小时前
01数据结构-交换排序
数据结构·算法
yzx9910132 小时前
Yolov模型的演变
人工智能·算法·yolo
源码宝2 小时前
【智慧工地源码】智慧工地云平台系统,涵盖安全、质量、环境、人员和设备五大管理模块,实现实时监控、智能预警和数据分析。
java·大数据·spring cloud·数据分析·源码·智慧工地·云平台
weixin_307779133 小时前
VS Code配置MinGW64编译SQLite3库
开发语言·数据库·c++·vscode·算法