leetcode295. 数据流的中位数

devtools/2024/12/23 2:06:53/

java">class MedianFinder {//A为小根堆,B为大根堆List<Integer> A,B;public MedianFinder() {A = new ArrayList<Integer>();B = new ArrayList<Integer>();}public void addNum(int num) {int m = A.size(),n = B.size();if(m == n){insert(B,num);int top = deleteTop(B);insert(A,top);}else{insert(A,num);int top = deleteTop(A);insert(B,top);}}//删除堆顶元素并返回其值private int deleteTop(List<Integer> list){Collections.swap(list,0,list.size() - 1);int heapSize = list.size() - 1;int root = 0;while(root < heapSize/2){int left = root * 2 + 1,right = root * 2 + 2,largest = root;if(left < heapSize && comparee(list,left,largest))largest = left;if(right < heapSize &&  comparee(list,right,largest))largest = right;if(root == largest)break;Collections.swap(list,root,largest);root = largest;}return list.remove(list.size() - 1);}//A小根堆的比较方法:比较值<目标值?private boolean comparee(List<Integer> list,int source,int target){if(list == A)return list.get(source) < list.get(target);elsereturn list.get(source) > list.get(target);}//将数插入到堆中private void insert(List<Integer> list,int num){list.add(num);int index = list.size() - 1;while(index > 0){int root = (index - 1) / 2;if(!comparee(list,index,root))break;Collections.swap(list,root,index);index = root;}}public double findMedian() {int m = A.size(),n = B.size();return (m==n) ? (A.get(0) + B.get(0)) / 2.0 : A.get(0);}
}


http://www.ppmy.cn/devtools/31477.html

相关文章

计算机等级考试2级(Python)知识点整理

计算机等级考试2级&#xff08;Python&#xff09;知识点整理 1.基础知识点&#xff08;记忆、理解&#xff09; 第1讲Python概述 01. 源代码 02. 目标代码 03. 编译和解释 04. 程序的基本编写方法 第2讲 Python语言基础&#xff08;一&#xff09; 01. 用缩进表示代码…

flutter实现选择图片视频上传到oss和图片视频的预览功能

一、效果图 flutter实现选择图片视频上传到oss和图片视频的预览功 二、所需要的依赖 image_picker: ^1.1.0 //选择图片 flutter_oss_aliyun: ^6.4.1 //图片上传到阿里云oss uuid: ^4.4.0 //生成唯一uuid interactiveviewer_gallery: ^0.6.0 //图片视频预览 cached_network_ima…

机器学习决策树模型

决策树模型从单一到集成 【机器学习】决策树&#xff08;上&#xff09;——ID3、C4.5、CART&#xff08;非常详细&#xff09;【机器学习】决策树&#xff08;中&#xff09;——Random Forest、Adaboost、GBDT &#xff08;非常详细&#xff09;【机器学习】决策树&#xff…

排序算法--直接选择排序

前提&#xff1a; 选择排序&#xff1a;选择排序(Selection sort)是一种比较简单的排序算法。它的算法思想是每一次从待排序的数据元素中选出最小(或最大)的一个元素&#xff0c;存放在序列的起始位置&#xff0c;直到全部待排序的数据元素排完。 话不多说&#xff0c;直接放图…

uboot-网络配置

文章目录 一、网络简介二、修改PHY芯片地址三、删除 uboot 中 74LV595 的驱动代码1.删除宏定义&#xff0c;添加ENET1和ENET2复位引脚&#xff0c;宏定义2.删除内容如下 四、添加 I.MX6U-ALPHA 开发板网络复位引脚驱动 一、网络简介 &#x1f4a6;I.MX6UL/ULL 内部有个以太网 …

Mac 版 安装NVM

优质博文IT-BLOG-CN NVM&#xff08;Node Version Manager&#xff09;是一个用于管理多个Node.js版本的工具。它允许开发者在同一台机器上安装和切换不同版本的Node.js&#xff0c;以便在不同的项目中使用不同的Node.js版本。macOS用户可以使用homebrew来安装NVM。 一、安装h…

20240503安装HEVC解码器播放H265格式的8K视频

20240503安装HEVC解码器播放H265格式的8K视频 2024/5/3 9:55 缘起&#xff1a;由于youtube支持8K视频了&#xff0c;想尝尝鲜&#xff01; 主摄像头当然是选择SONY的【夜摄/弱光场景】&#xff0c;根据优选&#xff0c;小米&#xff08;MI&#xff09;13Ultra 最佳了。 在开始播…

React Native支持Tailwind CSS 语法

React Native支持Tailwind CSS 语法 一、前沿背景 回想下我们平时按照官方的规范进行书写样式是什么样&#xff1f; 是像下面这样&#xff1a; const MyComponent () > {return (<View><Text style{{ fontSize: 20 }}>开发者演示专用</Text></View…