Java 数据结构篇-实现堆的核心方法与堆的应用(实现 TOP-K 问题:最小 k 个数)




public class MinHeap<T extends Comparable<T>> {
    private ArrayList<T> list;
 
    public MinHeap() {
        list = new ArrayList<>();
    }
 
    // 向堆中插入元素
    public void insert(T element) {
        list.add(element);
        siftUp(list.size() - 1);
    }
 
    // 从堆中取出最小元素
    public T extractMin() {
        if (list.isEmpty()) return null;
        T min = list.get(0);
        list.set(0, list.get(list.size() - 1));
        list.remove(list.size() - 1);
        siftDown(0);
        return min;
    }
 
    // 获取堆顶元素但不移除它
    public T getMin() {
        if (list.isEmpty()) return null;
        return list.get(0);
    }
 
    // 调整元素以满足堆的性质,向上调整
    private void siftUp(int index) {
        while (index > 0) {
            int parent = (index - 1) / 2;
            if (list.get(parent).compareTo(list.get(index)) <= 0) break;
            Collections.swap(list, parent, index);
            index = parent;
        }
    }
 
    // 调整元素以满足堆的性质,向下调整
    private void siftDown(int index) {
        int half = list.size() / 2;
        while (index < half) {
            // 找到子节点中较小的一个
            int child = (index * 2) + 1;
            if (child + 1 < list.size() && list.get(child + 1).compareTo(list.get(child)) < 0)
                child++;
            if (list.get(index).compareTo(list.get(child)) <= 0) break;
            Collections.swap(list, index, child);
            index = child;
        }
    }
 
    // 获取堆中元素的数量
    public int size() {
        return list.size();
    }
 
    // 判断堆是否为空
    public boolean isEmpty() {
        return list.isEmpty();
    }
 
    // 主函数,用于测试堆的创建和使用
    public static void main(String[] args) {
        MinHeap<Integer> minHeap = new MinHeap<>();
        int[] data = {10, 5, 15, 8, 20, 6};
 
        // 插入元素到堆中
        for (int num : data) {
            minHeap.insert(num);
        }
 
        // 获取最小的k个数
        int k = 3;
        for (int i = 0; i < k; i++) {
            System.out.println(minHeap.extractMin());
        }
    }
}

这段代码实现了一个最小堆,并展示了如何使用它来解决 TOP-K 问题。在主函数中,我们创建了一个最小堆并插入了一些数据,然后连续提取最小的 k 个数。这个过程模拟了堆的应用场景,对于学习数据结构和算法的学生来说具有很好的教育价值。

评论已关闭

推荐阅读

Vue中使用mind-map实现在线思维导图
2024年08月04日
VUE
Web前端最全Vue实现免密登录跳转的方式_vue怎么样不登录返回首页,最强技术实现
2024年08月04日
VUE
vue3 项目搭建教程(基于create-vue,vite,Vite + Vue)
2024年08月04日
VUE
Vue-颜色选择器实现方案——>Vue-Color( 实战*1+ Demo*7)
2024年08月04日
VUE
Vue项目卡顿慢加载?这些优化技巧告诉你!_vue数据多渲染卡顿
2024年08月04日
VUE
vue中的keep-alive详解与应用场景
2024年08月04日
VUE
Vue、React实现excel导出功能(三种实现方式保姆级讲解)
2024年08月04日
vue-office/docx插件实现docx文件预览
2024年08月04日
VUE
java调用js文件的两种方法(支持V8引擎)
2024年08月04日
JavaScript:解决计算精度问题/mathjs/bignumber.js/big.js/decimal.js
2024年08月04日
两周从爬虫小白变大神 _yjs_js_security_passport
2024年08月04日
JS笔记(对象、函数、数组)
2024年08月04日
Markdown.js:强大的纯JavaScript Markdown解析器
2024年08月04日
Vue项目:js模拟点击a标签下载文件并重命名,URL文件地址下载方法、请求接口下载文件方法总结。
2024年08月04日
vue 父组件怎么获取子组件里面的data数据
2024年08月04日
VUE
个人开发实现AI套壳网站快速搭建(Vue+elementUI+SpringBoot)
2024年08月04日
el-table 表格封装并改造实现单元格可编辑
2024年08月04日
none
nodejs环境下创建vue项目、SSH密钥登陆!!!
2024年08月04日
vue+quill+element-ui实现视频、图片上传及缩放保姆级教程,轻松使用富文本
2024年08月04日
【three.js】22. Imported Models导入模型
2024年08月04日