【灵神题单·贪心】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 的核心思想:从最大/最小开始贪心

相关推荐
唐青枫1 天前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
一个做软件开发的牛马1 天前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
用户3721574261351 天前
Java 处理 PDF 图片:提取 PDF 中的图片,并压缩 PDF 图片体积
java
用户3721574261351 天前
Java 打印 Word 文档:从基础打印到高级设置
java
用户3521802454752 天前
当 Prompt 学会"热更新":Spring Boot × Nacos3 AI 实战
java·spring boot·ai编程
东坡白菜2 天前
破局全栈:一个前端开发的Java入门实战记录(1)
java·全栈
唐青枫2 天前
Java Tomcat 实战指南:从 Servlet 容器到 Spring Boot 部署
java
wsaaaqqq2 天前
roudan:自由选择实体、灵活操作数据、快速写入数据库的 Java 框架
java
plainGeekDev2 天前
null 判断 → Kotlin 可空类型
android·java·kotlin
糖拌西瓜皮2 天前
Java开发者视角:深入理解Node.js异步编程模型
java·后端·node.js