算法的学习笔记—数据流中的中位数(牛客JZ41)

img

😀前言
在处理动态数据时,实时计算中位数是一个经典问题。中位数是排序后处于中间位置的数值,数据流中的中位数计算面临两个挑战:首先是数据量的动态变化,其次是需要保持元素的有序性。为了高效地解决这个问题,我们可以利用堆(Heap)结构。

🏠个人主页:尘觉主页

文章目录

  • 😀数据流中的中位数
    • 题目链接
    • 😄问题描述
    • 💖示例1
    • 💖示例2
    • 😊解题思路
    • 🤔代码实现
      • 代码解析
    • 😄总结

😀数据流中的中位数

题目链接

牛客网

😄问题描述

假设我们从数据流中不断读取数值,如果从中读取奇数个数值,中位数就是所有数值排序后位于中间的数值;如果读取偶数个数值,中位数就是排序后中间两个数值的平均值。

例如,输入数据流 [5, 2, 3, 4, 1, 6, 7, 0, 8],我们需要依次计算数据流的中位数,得到的结果为:5.00 3.50 3.00 3.50 3.00 3.50 4.00 3.50 4.00

💖示例1

输入:[5,2,3,4,1,6,7,0,8]

返回值:"5.00 3.50 3.00 3.50 3.00 3.50 4.00 3.50 4.00 "

说明:数据流里面不断吐出的是5,2,3…,则得到的平均数分别为5,(5+2)/2,3…

💖示例2

输入:[1,1,1]

返回值:"1.00 1.00 1.00 "

😊解题思路

为了高效地计算数据流的中位数,我们可以使用两个堆:大顶堆和小顶堆。

  • 大顶堆(Max-Heap):用于存储数据流中较小的一半元素,堆顶元素是这部分元素中的最大值。
  • 小顶堆(Min-Heap):用于存储数据流中较大的一半元素,堆顶元素是这部分元素中的最小值。

操作流程:

  1. 每当有新元素插入时,首先根据当前元素个数决定插入哪个堆。
    • 如果总数为偶数,则新元素应插入小顶堆。但为了保证小顶堆的元素都大于大顶堆中的元素,我们可以先将新元素插入大顶堆,再将大顶堆堆顶的最大值弹出并插入小顶堆。
    • 如果总数为奇数,则新元素应插入大顶堆。同样,为了保证大顶堆的元素都小于小顶堆的元素,我们可以先将新元素插入小顶堆,再将小顶堆堆顶的最小值弹出并插入大顶堆。
  2. 插入操作结束后,根据堆中元素的数量计算中位数:
    • 如果总数为偶数,中位数为两个堆顶元素的平均值。
    • 如果总数为奇数,中位数为小顶堆的堆顶元素。

🤔代码实现

以下是用 Java 实现的代码示例

import java.util.PriorityQueue;public class MedianFinder {/* * 大顶堆,存储数据流中较小的一半元素 * 比较器设为倒序,这样堆顶为最大值*/private PriorityQueue<Integer> left = new PriorityQueue<>((o1, o2) -> o2 - o1);/* * 小顶堆,存储数据流中较大的一半元素 * 默认是最小堆,堆顶为最小值*/private PriorityQueue<Integer> right = new PriorityQueue<>();/* 当前数据流中元素的总数 */private int N = 0;/*** 插入新元素到数据流中* * @param val 要插入的数据流中的新值*/public void Insert(Integer val) {/* 插入操作:首先根据当前元素数量的奇偶性,决定插入哪个堆 */if (N % 2 == 0) {/** 当 N 为偶数时:* - 先将新元素插入大顶堆(左半边),确保左半边堆顶最大。* - 然后将大顶堆中的最大值弹出并插入小顶堆(右半边),*   这样就保证了右半边的元素都大于左半边的元素。*/left.add(val);right.add(left.poll());} else {/** 当 N 为奇数时:* - 先将新元素插入小顶堆(右半边),确保右半边堆顶最小。* - 然后将小顶堆中的最小值弹出并插入大顶堆(左半边),*   这样就保证了左半边的元素都小于右半边的元素。*/right.add(val);left.add(right.poll());}/* 插入完成后,元素总数加一 */N++;}/*** 获取当前数据流的中位数* * @return 当前数据流的中位数*/public Double GetMedian() {/* * 判断元素总数的奇偶性来决定中位数的计算方式 * 如果总数为偶数,中位数为两个堆顶元素的平均值* 如果总数为奇数,中位数为小顶堆的堆顶元素*/if (N % 2 == 0)return (left.peek() + right.peek()) / 2.0;elsereturn (double) right.peek();}public static void main(String[] args) {MedianFinder mf = new MedianFinder();int[] nums = {5, 2, 3, 4, 1, 6, 7, 0, 8};/* * 逐个插入元素到数据流,并输出当前的中位数 */for (int num : nums) {mf.Insert(num);System.out.print(mf.GetMedian() + " ");}}
}

代码解析

  • 堆的构建:我们使用了 Java 的 PriorityQueue 类来实现大顶堆和小顶堆。大顶堆通过传入自定义比较器来实现,将较大元素优先弹出。小顶堆则是默认的最小堆。
  • 插入逻辑:根据当前元素数量的奇偶性,决定元素插入的顺序。通过先插入一个堆,再将该堆顶元素移动到另一个堆,保证两个堆中的数据始终保持平衡。
  • 获取中位数:根据元素的奇偶性,决定从哪个堆中获取中位数。如果元素总数为偶数,则取两个堆的堆顶元素平均值;如果为奇数,则直接返回小顶堆的堆顶元素。

😄总结

这种使用双堆(大顶堆和小顶堆)的方法使得我们能够高效地从数据流中计算中位数。由于堆结构的特性,插入元素和获取中位数的时间复杂度都为 O(log n),满足了题目对时间复杂度的要求。这种方法不仅适用于题目给定的范围,还可以扩展到更大规模的数据流处理中。

😁热门专栏推荐
想学习vue的可以看看这个

java基础合集

数据库合集

redis合集

nginx合集

linux合集

手写机制

微服务组件

spring_尘觉

springMVC

mybits

等等等还有许多优秀的合集在主页等着大家的光顾感谢大家的支持

🤔欢迎大家加入我的社区 尘觉社区

文章到这里就结束了,如果有什么疑问的地方请指出,诸佬们一起来评论区一起讨论😁
希望能和诸佬们一起努力,今后我们一起观看感谢您的阅读🍻
如果帮助到您不妨3连支持一下,创造不易您们的支持是我的动力🤞

img

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/410867.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

并发式服务器

并发式服务器是一种设计用来同时处理多个客户端请求的服务器。这种服务器能够提高资源利用率和响应速度&#xff0c;适用于需要服务大量用户的网络应用。以下是并发式服务器的一些关键特点&#xff1a; 多任务处理&#xff1a;并发式服务器能够同时处理多个任务或请求&#xff…

DDOS攻击学习-渗透测试-域名信息收集

文章目录 wordpress漏洞利用域名信息收集域名介绍域名分类 whoiswhois反查子域名收集子域名发现网络空间安全搜索引擎SSL证书查询js文件发现子域名 wordpress漏洞利用 这个一般都需要安装wordpress服务使用wpscan扫描&#xff0c;但现在一般很少人知道或者使用wordpress所以这个…

Mysql的查询指令

整理了一些Mysql的查询语句&#xff0c;希望对大家有帮助&#xff0c;祝大家心想事成万事如意&#xff01; 基本查询 select 字段 from 表名 where 条件&#xff1b; 排序查询 select 字段 from 表名 order by 排序字段 [asc升序|desc降序] limit 前几行/中间几行&#xff1…

美股投资迷思大揭秘:理性投资,绕开六大陷阱

你是否也对美股投资充满了期待&#xff0c;但又担心踏入误区&#xff1f;美股市场作为全球金融的璀璨明珠&#xff0c;吸引着无数投资者的目光&#xff0c;但同时也伴随着一些常见的误解。今天&#xff0c;我们就来一一拆解这些迷思&#xff0c;助你美股投资之路更加顺畅&#…

产品中的影响力六大原则

罗伯特B西奥迪尼(Robert B. Cialdini)是全球知名的说服术与影响力研究权威专家。他在著作《影响力&#xff1a;说服心理学》中提出有效的影响和说服必须遵循统一的六项心理学原则&#xff1a;互惠、承诺与一致、社会认同、喜好、权威和稀缺性。不论在生活还工作中我们或多或少会…

算法-有效的字母异位词

这道题很简单&#xff0c;就不做过多的解释&#xff0c;只需要创建一个哈希表统计s中出现的次数&#xff0c;然后遍历t&#xff0c;如果没找到&#xff0c;或者找到了但是次数为0则返回错误&#xff0c;否则返回true。代码如下&#xff1a; class Solution { public:bool isAn…

【python】Python如何通过FFmpeg处理音视频

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

06:【江科大stm32】:定时器输入捕获功能

定时器输入捕获功能 1、通过定时器的输入捕获功能测量PWM波的频率2、PWMI模式测量频率和占空比 1、通过定时器的输入捕获功能测量PWM波的频率 定时器标准库相关的编程接口&#xff1a; ①PWM.c文件的代码如下&#xff1a; /*通过定时器TIM2生成一个分辨率为10us,频率为1KHz的…

RabbitMQ中的死信交换机?(RabbitMQ延迟队列有了解过吗)

延迟队列 延迟队列:进入队列的消息会被延迟消费的队列。 延迟队列死信交换机 TTL&#xff08;过期时间&#xff09; 延迟队列的使用场景:超时订单、限时优惠、定时发布 死信交换机 当一个队列中的消息满足下列情况之一时&#xff0c;可以成为死信(dead letter): 消费者使…

iOS工程:获取手机相册权限,iOS原生系统弹窗, Privacy隐私政策选择,如何添加系统弹出并修改描述文字

【iOS工程】获取手机相册权限&#xff0c;iOS原生系统弹窗, Privacy隐私政策选择&#xff0c;如何添加系统弹出并修改描述文字 设备/引擎&#xff1a;Mac&#xff08;11.6&#xff09;/Mac Mini 开发工具&#xff1a;Xcode&#xff08;15.0.1&#xff09; 开发需求&#xff…

【Java设计模式】Builder模式:在Java中清晰构建自定义对象

文章目录 【Java设计模式】Builder模式&#xff1a;在Java中清晰构建自定义对象一、概述二、Builder设计模式的意图三、Builder模式的详细解释及实际示例四、Java中Builder模式的编程示例五、Builder模式类图六、Java中何时使用Builder模式七、Builder模式的优点和权衡八、源码…

YOLO-World: Real-Time Open-Vocabulary Object Detection:实时开放词汇对象检测

YOLO系列探测器已成为高效实用的工具。然而&#xff0c;它们对预定义和训练的对象类别的依赖限制了它们在开放场景中的适用性。针对这一限制&#xff0c;我们引入了YOLO-World&#xff0c;这是一种创新方法&#xff0c;通过视觉语言建模和大规模数据集的预训练&#xff0c;增强…

.NET8 Web 利用BAT命令 一键部署 IIS - CI-CD基础

1. Windows Server 前置准备 1.1 IIS安装好 1.2 .NET8 Sdk 运行时 安装 官方下载地址&#xff1a;https://dotnet.microsoft.com/zh-cn/download/dotnet/8.0 1.3 创建一个.NET8 WebMvc项目 生成发布包 微软MVC这个项目模板直接创建&#xff0c;发布 2. 利用 BAT 来一键部署…

Aigtek功率放大器应用领域分享:无处不在的MEMS传感器

微机电系统&#xff08;MEMS,Micro-Electro-MechanicalSystem&#xff09;&#xff0c;也叫做微电子机械系统、微系统、微机械等&#xff0c;指尺寸在几毫米乃至更小的高科技装置。微机电系统其内部结构一般在微米甚至纳米量级。微机电系统是在微电子技术&#xff08;半导体制造…

分布式基础理论——CAP理论和BASE理论

文章目录 CAP 理论BASE 理论参考资料 CAP 理论 CAP定理&#xff08;CAP theorem&#xff09;指出&#xff0c;在分布式系统中&#xff0c;设计读写操作时只能同时满足以下三个特性中的两个&#xff1a; 一致性&#xff08;Consistency&#xff09; : 所有节点访问同一份最新的…

ssm基于微信小程序的食堂窗口自助点餐系统源码调试讲解

1. 环境搭建 JDK 1.8&#xff1a;确保您的系统已安装JDK 1.8&#xff0c;并配置好环境变量。JDK 1.8 是目前很多Java项目仍在使用的稳定版本&#xff0c;适用于SSM框架。Tomcat 7&#xff1a;安装并配置Tomcat 7作为您的Web服务器。Tomcat 7 支持Servlet 3.0和JSP 2.2&#xf…

杰发科技AC7801——Flash模拟EEP内存(2)

1. 默认配置在1000个地址存储1000个数据 配置如下 计算地址 查看地址内容&#xff0c;等到打印完成 计算符合&#xff0c;从0-999共计1000 2. 修改配置在65536地址存储65536个数据 配置还是这个 因为传进去的地址是uint16_t&#xff0c;因此最大值是65536&#xff0c;写65536…

基于Pytorch框架的深度学习PSPnet网络动物马语义分割系统源码

第一步&#xff1a;准备数据 动物马分割数据&#xff0c;总共有328张图片&#xff0c;里面的像素值为0和1&#xff0c;所以看起来全部是黑的&#xff0c;不影响使用 第二步&#xff1a;搭建模型 psp模块的样式如下&#xff0c;其psp的核心重点是采用了步长不同&#xff0c;po…

前端:html+css:伪类画箭头(实心)

一、效果图 二、代码 html <div class"rectangle">AC/DC</div> css /* 图形 */ .rectangle {position: relative;width: 50px;height: 20px;background-color: #3498db;color: white; } .rectangle:before {content: ;position: absolute;top: 0;l…

Spring Boot Web开发实践:请求与响应参数的使用方法

主要介绍了请求响应的简单参数、实体参数、数组集合参数、日期参数、路径参数等各自的使用方法&#xff01;&#xff01;&#xff01; 文章目录 前言 Postman 简单参数 原始方式 SpringBoot方式 实体参数 数组集合参数 日期参数 路径参数 总结 前言 主要介绍了请求响应的简单参…