【灵神题单·贪心】3745. 三元素表达式的最大值 | 排序贪心 | Java

🔗 题目链接:3745. 三元素表达式的最大值

📚 所属题单:灵茶山艾府 · 贪心算法题单 --- §1.1 从最小/最大开始贪心

🏷️ 难度:Easy | 难度分:1218

🔖 标签:贪心、数组、排序

📖 题目描述

给你一个整数数组 nums

nums 中选择三个元素 abc,它们的下标需互不相同 ,使表达式 a + b - c 的值最大化。

返回该表达式可能的 最大值

示例 1

复制代码
输入:nums = [1,4,2,5]
输出:8
解释:选择 a = 4,b = 5,c = 1。表达式的值为 4 + 5 - 1 = 8,这是可能的最大值。

示例 2

复制代码
输入:nums = [-2,0,5,-2,4]
输出:11
解释:选择 a = 5,b = 4,c = -2。表达式的值为 5 + 4 - (-2) = 11,这是可能的最大值。

提示

  • 3 <= nums.length <= 100
  • -100 <= nums[i] <= 100

💡 思路分析

a + b - c 要最大化,拆开来看:

  • a + b 要尽量大 → 选最大的两个数
  • c 要尽量小 → 选最小的那个数

由于 a、b、c 下标互不相同(但数组至少 3 个元素),排序后最大的两个和最小的那个肯定不会重叠(除非数组恰好 3 个元素,那也没问题)。

这就像买菜------你手里拿着两个最贵的菜,然后找到商场里最便宜的一个打折扣。总价减去折扣,收益最大 💰

算法步骤

  1. 排序:把数组从小到大排
  2. 返回结果nums[n-1] + nums[n-2] - nums[0](最大的两个减最小的)

就这么简单,一行搞定。

✅ 代码实现(Java)

java 复制代码
class Solution {
    public int maximizeExpressionOfThree(int[] nums) {
        // 排序:最小的在前,最大的在后
        Arrays.sort(nums);
        int n = nums.length;
        // a + b 取最大的两个,c 取最小的那个
        return nums[n - 1] + nums[n - 2] - nums[0];
    }
}

📊 复杂度分析

复杂度 说明
⏱️ 时间 O(n log n) 排序
💾 空间 O(log n) 排序的栈空间

🔗 参考

🎯 这题简单到有点不好意思说它是贪心------排序后首尾各取一下就完了。但它完美诠释了 §1.1 的核心思想:从最大/最小开始贪心

相关推荐
Tian_Hang15 小时前
Factory Method | 工厂方法
开发语言·c++
wearegogog12315 小时前
基于MATLAB实现雷达RCS Swerling模型
开发语言·matlab
星梦清河15 小时前
Java—异步编程
java·开发语言
GIS数据转换器15 小时前
智慧能源管理平台
java·大数据·运维·人工智能·无人机
garmin Chen15 小时前
LeetcodeHot100打卡(14、合并空间,15、轮转数组,16、除了自身以外数组乘积,17.缺失的第一个整数)
java·笔记·学习·算法
接着奏乐接着舞15 小时前
dto 转entity方法
java·开发语言
我命由我1234515 小时前
Android 开发问题:项目同时引入了两个包含相同类文件的库(AndroidX 库、旧版本支持库),导致了重复类错误
android·java·java-ee·android studio·android-studio·androidx·android runtime
0x000716 小时前
译 Anders Hejlsberg 谈 C# 与 .NET
开发语言·c#·.net
梓色系16 小时前
Spring AI 实战:从零搭建 MCP 客户端与服务端,让大模型拥有“手脚“
java·人工智能·spring
czhaii16 小时前
基于51单片机的Modbus从机通信系统
开发语言·单片机