B.双指针——3194. 最小元素和最大元素的最小平均值

题目链接:3194. 最小元素和最大元素的最小平均值(简单)

算法原理:

解法:排序+对撞双指针

击败9.52%

时间复杂度O(Nlogn)

先排序,然后设置对撞双指针逐层判断取二者和的最小值,在返回的时候统一÷2即可

Java代码:

java 复制代码
class Solution {
    public double minimumAverage(int[] nums) {
        Arrays.sort(nums);
        int n=nums.length;
        int left=0,right=n-1;
        double ret=0x3f3f3f3f;
        while(left<right){
            int tmp=nums[left]+nums[right];
            ret=(double)tmp<ret?(double)tmp:ret;
            left++;right--;
        }
        return ret/2.0;
    }
}
相关推荐
SalvoGao2 小时前
Python学习 | 怎么理解epoch?
数据结构·人工智能·python·深度学习·学习
Charles_go2 小时前
C#中级、double和decimal有什么区别
开发语言·c#
程序猿20232 小时前
项目结构深度解析:理解Spring Boot项目的标准布局和约定
java·spring boot·后端
思成不止于此2 小时前
深入理解 C++ 多态:从概念到实现的完整解析
开发语言·c++·笔记·学习·多态·c++40周年
csbysj20202 小时前
Ruby 字符串(String)
开发语言
RainbowSea2 小时前
内网穿透配置和使用
java·后端
RainbowSea2 小时前
13. Spring AI 的观测性
java·spring·ai编程
基哥的奋斗历程3 小时前
Kotlin_Flow_完整使用指南
android·开发语言·kotlin
心之伊始3 小时前
Java synchronized 锁升级全过程深度解析:从 Mark Word 到偏向锁、轻量级锁与重量级锁的 HotSpot 实现
java·开发语言·word