​LeetCode解法汇总1093. 大样本统计

news/2024/7/1 2:46:22

目录链接:

力扣编程题-解法汇总_分享+记录-CSDN博客

GitHub同步刷题项目:

https://github.com/September26/java-algorithms

原题链接:力扣


描述:

我们对 0 到 255 之间的整数进行采样,并将结果存储在数组 count 中:count[k] 就是整数 k 在样本中出现的次数。

计算以下统计数据:

  • minimum :样本中的最小元素。
  • maximum :样品中的最大元素。
  • mean :样本的平均值,计算为所有元素的总和除以元素总数。
  • median :
    • 如果样本的元素个数是奇数,那么一旦样本排序后,中位数 median 就是中间的元素。
    • 如果样本中有偶数个元素,那么中位数median 就是样本排序后中间两个元素的平均值。
  • mode :样本中出现次数最多的数字。保众数是 唯一 的。

以浮点数数组的形式返回样本的统计信息 [minimum, maximum, mean, median, mode] 。与真实答案误差在 10-5 内的答案都可以通过。

示例 1:

输入:count = [0,1,3,4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]
输出:[1.00000,3.00000,2.37500,2.50000,3.00000]
解释:用count表示的样本为[1,2,2,2,3,3,3,3]。
最小值和最大值分别为1和3。
均值是(1+2+2+2+3+3+3+3) / 8 = 19 / 8 = 2.375。
因为样本的大小是偶数,所以中位数是中间两个元素2和3的平均值,也就是2.5。
众数为3,因为它在样本中出现的次数最多。

示例 2:

输入:count = [0,4,3,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]
输出:[1.00000,4.00000,2.18182,2.00000,1.00000]
解释:用count表示的样本为[1,1,1,1,2,2,3,3,3,4,4]。
最小值为1,最大值为4。
平均数是(1+1+1+1+2+2+2+3+3+4+4)/ 11 = 24 / 11 = 2.18181818…(为了显示,输出显示了整数2.18182)。
因为样本的大小是奇数,所以中值是中间元素2。
众数为1,因为它在样本中出现的次数最多。

提示:

  • count.length == 256
  • 0 <= count[i] <= 109
  • 1 <= sum(count) <= 109
  •  count 的众数是 唯一 的

解题思路:

/**

* 最小,最大,平均值,最多都比较简单,重点是中位数。

* 因为数量很多,我们挨个去统计肯定不合适,

* 所以我们首先可以总数量,然后分别求matchleft和matchright代表左右的中位数,如果是基数的话matchright=matchright。

* 然后我们不断的sum去减掉count[i]的值,当num <= matchright时,说明已经走到了右侧的中位数,这时候记录其值到medianValue。num <= matchleft时也是一样。

* 最后medianValue/2就是我们的预期中位数。

*/

 

代码:

#include <iostream>
#include <map>
#include <list>
#include <vector>
#include <set>
#include <algorithm>

using namespace std;

/**
 * 最小,最大,平均值,最多都比较简单,重点是中位数。
 * 因为数量很多,我们挨个去统计肯定不合适,
 * 所以我们首先可以总数量,然后分别求matchleft和matchright代表左右的中位数,如果是基数的话matchright=matchright。
 * 然后我们不断的sum去减掉count[i]的值,当num <= matchright时,说明已经走到了右侧的中位数,这时候记录其值到medianValue。num <= matchleft时也是一样。
 * 最后medianValue/2就是我们的预期中位数。
 */
class Solution
{
public:
    vector<double> sampleStats(vector<int> &count)
    {
        vector<double> list;
        double minValue = -1;
        double maxValue = -1;
        double meanValue = 0;
        double medianValue = 0;
        double modeValue = 0;
        // 最大数量
        int maxNum = 0;
        // 总数量
        int num = 0;
        // 总的累加值
        double sum = 0;
        for (int i = 0; i < count.size(); i++)
        {
            if (count[i] == 0)
            {
                continue;
            }
            num += count[i];
            sum += (count[i] * (long)i);
            maxValue = i;
            if (minValue == -1)
            {
                minValue = i;
            }
            if (count[i] > maxNum)
            {
                modeValue = i;
                maxNum = count[i];
            }
        }
        meanValue = sum / num;

        // 求中位数
        int matchleft = 0;
        int matchright = 0;
        if (num % 2 == 0)
        {
            matchleft = num / 2 - 1;
            matchright = num / 2;
        }
        else
        {
            matchleft = num / 2;
            matchright = num / 2;
        }

        for (int i = 0; i < count.size(); i++)
        {
            num -= count[i];
            if (num <= matchright)
            {
                medianValue += i;
                matchright = -1;
            }
            if (num <= matchleft)
            {
                medianValue += i;
                break;
            }
        }
        medianValue = medianValue / 2;
        list.push_back(minValue);
        list.push_back(maxValue);
        list.push_back(meanValue);
        list.push_back(medianValue);
        list.push_back(modeValue);
        return list;
    }
};


http://lihuaxi.xjx100.cn/news/1231671.html

相关文章

chatgpt赋能python:Python中如何取出字符串中的数字并赋予新的变量

Python 中如何取出字符串中的数字并赋予新的变量 在 Python 中&#xff0c;我们经常需要处理字符串&#xff0c;其中可能包含多种类型的数据。当我们需要获取字符串中的数字时&#xff0c;该怎样做呢&#xff1f;本文将介绍取出字符串中的数字的方法&#xff0c;并赋予新的变量…

Java入门之String 学习随记(一)

一. 前置知识 API-Application Programming Interface-应用程序编程接口,接口可以简单理解为别人写好的东西,我们拿过来直接使用即可.顾名思义,JavaAPI指的就是JDK提供的各种功能的Java类,它们将底层的实现封装了起来. 二. java.lang.String 该类为字符串,在Java中所有字符串…

JUC并发编程工具

java的并发编程工具&#xff0c;全称java.util.concurrent 什么是分布式事务&#xff1f; 分布式事务是指事务的参与者、支持事务的服务器、资源协调者和事务的管理者 分布在不同的分布式系统的不同节点上。 在分布式系统中一个大的操作可能涉及很多小的操作&#xff0c;这些…

chatgpt赋能python:Python中如何取出字符串中的字符

Python中如何取出字符串中的字符 在Python编程中&#xff0c;经常会涉及到需要对字符串中的字符进行操作&#xff0c;比如提取某些特定的字符等。那么&#xff0c;Python中如何取出字符串中的字符呢&#xff1f;本文将为您进行详细介绍。 1. 使用索引 在Python中&#xff0c…

尚硅谷甄选--更新中

文章目录 搭建后台管理系统模板项目初始化2.1.1环境准备2.1.2初始化项目2.2项目配置一、eslint配置1.1vue3环境代码校验插件1.2修改.eslintrc.cjs配置文件1.3.eslintignore忽略文件1.4运行脚本 二、配置**prettier**2.1安装依赖包2.2.prettierrc.json添加规则2.3.prettierignor…

chatgpt赋能python:Python字符类型判断:如何判断字符是字母或数字

Python字符类型判断&#xff1a;如何判断字符是字母或数字 在Python编程中&#xff0c;经常需要判断一个字符是字母还是数字。本文将介绍如何在Python中判断字符类型&#xff0c;并给出几个示例。 判断字符类型的方法 在Python中&#xff0c;可以使用以下方法来判断字符类型…

C语言之函数栈帧的创建与销毁(2)

上一篇博客我们讲到了函数栈帧的创建与销毁&#xff08;1&#xff09;今天我们来讲解Add函数的函数栈帧相关知识 在开始本章博客之前&#xff0c;大家可以把上一篇博客的主要内容仔细复习一下 看图 第一个mov&#xff1a;把b的值放到eax里面去 第二个mov&#xff1a;把a的…

【华为OD统一考试B卷 | 100分】数据分类(C++ Java JavaScript Python)

题目描述 对一个数据a进行分类,分类方法为: 此数据a(四个字节大小)的四个字节相加对一个给定的值b[取模]如果得到的结果小于一个给定的值c,则数据a为有效类型,其类型为取模的值;如果得到的结果大于或者等于c,则数据a为无效类型。 比如一个数据a=0x01010101,b=3,按…