【社招+校招】华为OD机试 - 查找众数及中位数(Java & JS & Python & C & C++)

鱼弦:公众号【红尘灯塔】,优快云博客专家、内容合伙人、新星导师、全栈领域优质创作者 、51CTO(Top红人+专家博主) 、github开源爱好者(go-zero源码二次开发、游戏后端架构 https://github.com/Peakchen)

本项目旨在实现查找众数及中位数的算法,并提供 Java、JavaScript、Python、C 和 C++ 版本的完整代码、详细解释和测试方案。

问题描述

1. 查找众数

给定一个非空数组,找到出现次数最多的元素。如果存在多个众数,可以输出任意一个。

2. 查找中位数

给定一个非空数组,将其由小到大排序,找到位于数组中间位置的元素。如果数组长度为偶数,则取中间两个元素的平均值作为中位数。

算法实现

1. 查找众数

1.1 哈希表法

原理: 利用哈希表来记录每个元素出现的次数,时间复杂度为 O(n),空间复杂度为 O(n)。

Java 代码:

import java.util.HashMap;
import java.util.Map;

public c
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鱼弦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值