LeetCode 每日一题 最小元素和最大元素的最小平均值

最小元素和最大元素的最小平均值

你有一个初始为空的浮点数数组 averages。另给你一个包含 n 个整数的数组 nums,其中 n 为偶数。

你需要重复以下步骤 n / 2 次:

从 nums 中移除 最小 的元素 minElement 和 最大 的元素 maxElement。

将 (minElement + maxElement) / 2 加入到 averages 中。

返回 averages 中的 最小 元素。

示例 1:

输入: nums = [7,8,3,4,15,13,4,1]

输出: 5.5

示例 2:

输入: nums = [1,9,8,3,10,5]

输出: 5.5

输入: nums = [1,2,3,7,8,9]

输出: 5.0

提示:

2 <= n == nums.length <= 50

n 为偶数。

1 <= nums[i] <= 50

题解

根据题目要求,我们需要不断找到数组中的最大与最小值然后将其移除,找到和最小的一组最大最小值,返回其*0.5

那么很容易想到先将数组 nums 进行排序,然后依次选取两边的数据为一组,记录最小的组

然后将最小值*0.5就是需要的答案

这里最后再做*0.5运算可以减少浮点运算的次数,从而提高效率

代码如下↓

c 复制代码
int cmp(const void* a,const void* b)
{
    return *(int*)a - *(int*)b;
}
double minimumAverage(int* nums, int numsSize) {
    qsort(nums,numsSize,sizeof(int),cmp);
    int l=0,r=numsSize-1;
    double min=999999;
    while(l<r)
    {
        if(nums[l]+nums[r]<min)
        {
            min=nums[l]+nums[r];
        }
        l++;
        r--;
    }
    min/=2;
    return min;
}
相关推荐
蒙奇D索大几秒前
【数据结构】排序算法精讲|折半插入排序全解:高效优化、性能对比、实战剖析
数据结构·学习·考研·算法·排序算法·改行学it
汽车仪器仪表相关领域4 分钟前
ZDT-III 通用电机测试系统
数据库·算法·单元测试·压力测试·可用性测试
前端小白在前进7 分钟前
力扣刷题:矩阵重叠
算法·leetcode·矩阵
啊阿狸不会拉杆14 分钟前
《数字图像处理》-实验1
图像处理·人工智能·算法·计算机视觉·数字图像处理
黎雁·泠崖21 分钟前
C 语言联合体与枚举:共用内存 + 常量枚举 + 实战
c语言·开发语言·python
zore_c23 分钟前
【C语言】排序算法——快速排序详解(含多种变式)!!!
c语言·数据结构·笔记·算法·排序算法·深度优先·推荐算法
Savior`L28 分钟前
字符串哈希
c++·算法·哈希算法·散列表
啊阿狸不会拉杆29 分钟前
《数字图像处理》实验3-频率域处理方法
图像处理·人工智能·算法·计算机视觉·数字图像处理
代码游侠35 分钟前
应用——HTTP天气查询
网络·笔记·网络协议·算法·http