LeetCode 1093. 大样本统计

  1. 大样本统计

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

我们以 浮点数 数组的形式,分别返回样本的最小值、最大值、平均值、中位数和众数。其中,众数是保证唯一的。

我们先来回顾一下中位数的知识:

如果样本中的元素有序,并且元素数量为奇数时,中位数为最中间的那个元素;
如果样本中的元素有序,并且元素数量为偶数时,中位数为中间的两个元素的平均值。

示例 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]

示例 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.length == 256
1 <= sum(count) <= 10^9
计数表示的众数是唯一的
答案与真实值误差在 10^-5 以内就会被视为正确答案

题解

无聊的题目。。。。。

class Solution {
public:
    typedef long long ll;
    ll sum[300];
    vector<double> sampleStats(vector<int>& count) 
    {
        sum[0] = count[0];
        ll mi=1e9,mx=-1e9,ans=0,id=0;
        ll total = 0;
        if(count[0]>0)
        {
            mi=min(mi,(ll)0);
            mx=max(mx,(ll)0);
            ans=count[0];
            id=0;
        }
        for(int i=1;i<count.size();i++)
        {
            sum[i] = sum[i-1]+count[i];
            if(count[i]>0)
            {
                total += (ll)count[i]*(ll)i;
                mi=min(mi,(ll)i);
                mx=max(mx,(ll)i);
                if(count[i]>ans)
                {
                    ans=count[i];
                    id=i;                        
                }
            }
        }
        double aver = 0;
        if(sum[count.size()-1]%2==1)
        {
            int mid=sum[count.size()-1]/2+1;
            for(int i=0;i<count.size()-1;i++)
            {
                if(sum[i]>=mid)
                {
                    aver=i;
                    break;
                } 
            }
        }
        else
        {
            int mid=sum[count.size()-1]/2;
            for(int i=0;i<count.size()-1;i++)
            {
                if(sum[i]>=mid)
                {
                    aver=i;
                    if(sum[i]==mid)//需要再找一个
                    {
                        for(int j=i+1;j<count.size();j++)
                        {
                            if(count[j]>0)
                            {
                                aver+=j;
                                break;
                            }
                        }
                        aver/=2;
                    }
                    break;
                } 
            }    
            
        }
        vector<double>res;
        res.push_back(double(mi));
        res.push_back(double(mx));
        res.push_back(double(total)/double(sum[count.size()-1]));
        res.push_back(aver);
        res.push_back(double(id));
        return res;
    }
};

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值