当前位置: 首页 > article >正文

【华为OD】2024D卷——查找众数与中位数

题目:
众数是指一组数据中出现次数量多的那个数,众数可以是多个。
中位数是指把一组数据从小到大排列,最中间的那个数,如果这组数据的个数是奇数,那最中间那个就是中位数,如果这组数据的个数为偶数,那就把中间的两个数之和除以2,所得的结果就是中位数。
查找整型数组中元素的众数并组成一个新的数组,求新数组的中位数。

输入描述:
输入一个一维整型数组
数组大小取值范围0<N<1000,数组中每个元素取值范围0<E<1000

输出描述:
输出众数组成的新数组的中位数

示例1
输入
10 11 21 19 21 17 21 16 21 18 15
输出
21

示例2
输入
2 1 5 4 3 3 9 2 7 4 6 2 15 4 2 4
输出
3

解题思路:

1、统计数字频率

2、找出众数(频率最大数),组成新数组

3、计算新数组中位数


代码部分:

def median_in_mode(nums):

    # # 使用hash表(字典) 统计频率
    # freq = {}
    # for num in nums:
    #     if num in freq:
    #         freq[num] += 1
    #     else:
    #         freq[num] = 1
    # max_freq = max(freq.values())   #最大次数
    # new_nums= [num for num, cnt in freq.items() if cnt == max_freq]
    
    # 使用数组统计频率
    new_nums = []  # 存储众数
    nums_count = []  # 存储计数
    for x in nums:
        nums_count.append(nums.count(x))
    # max_time = max(x for x in nums_count)    #最大次数
    max_time = max(nums_count)
    for x in nums:
       if nums.count(x) == max_time:
           new_nums.append(x)
    length = len(new_nums)
    new_nums.sort()  #众数数组排序
    if length % 2 == 0:
       result = (new_nums[length // 2] + new_nums[length // 2 - 1]) // 2        #偶数位,返回中间两值平均数
    else:
       result = new_nums[length // 2]       #奇数位,返回中间值
    return result


if __name__ == '__main__':
    nums = list(map(int, input().split()))
    result = median_in_mode(nums)
    print(result)

知识点:列表、hash表


结语:越简单的题目解法应该越多,请路过大神留下新的思路供本小白学习一下,打开思路


http://www.kler.cn/news/292551.html

相关文章:

  • MacBook真的不能打游戏吗?Mac打游戏会损坏电脑吗?苹果电脑怎么玩游戏
  • 如何在 Java 中实现线程安全的单例模式?
  • 前端宝典二十七:React Native最佳实践实例推荐
  • 强化网络安全:通过802.1X协议保障远程接入设备安全认证
  • 迭代器 Iterator 是什么?
  • Linux修改docker默认存储目录(/var/lib)
  • Twitter上品牌安全指标的关键显示错误已修正
  • 2024跨境旺季营销:哪个平台是流量之王?
  • Ribbon负载均衡底层原理
  • 配置阿里云千问大模型--环境变量dashscope
  • 基于Openface在ubuntu上抽取人脸图像
  • 02【SQL sever 2005数据库安装教程】
  • python学习第三节:创建第一个python项目
  • Python 数据分析— Numpy 基本操作(下)
  • 【大模型实战篇】大模型周边NLP技术回顾及预训练模型数据预处理过程解析(预告)
  • tkcalendar中的DateEntry
  • CLION+gdbserver远程调试postgresql源码
  • 前端Vue框架,本地数据库nedb
  • python 打包tkinter图标问题
  • fastadmin 文件上传七牛云
  • html中,想添加一段文字,使用什么标签最合理?
  • nginx的基本使用示例(负载均衡,虚拟主机,动静分离)的详细配置过程
  • 2024挖漏洞给报酬的网站汇总,兼职副业3天收益2k
  • 路灯线路电气安全存在的问题与防护措施
  • ARM基础知识
  • 使用C++编写接口调用PyTorch模型,并生成DLL供.NET使用
  • pytest 常用的辅助函数和工具函数
  • springboot 实现策略模式通过id进入不同的服务类service
  • C++ 设计模式——解释器模式
  • 免费OCR 文字识别工具