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

相关推荐
一灯架构2 小时前
90%的人答错!一文带你彻底搞懂ArrayList
java·后端
踏着七彩祥云的小丑2 小时前
pytest——Mark标记
开发语言·python·pytest
Dream of maid2 小时前
Python12(网络编程)
开发语言·网络·php
W23035765732 小时前
经典算法:最长上升子序列(LIS)深度解析 C++ 实现
开发语言·c++·算法
Y4090013 小时前
【多线程】线程安全(1)
java·开发语言·jvm
不爱吃炸鸡柳3 小时前
Python入门第一课:零基础认识Python + 环境搭建 + 基础语法精讲
开发语言·python
布局呆星3 小时前
SpringBoot 基础入门
java·spring boot·spring
minji...3 小时前
Linux 线程同步与互斥(三) 生产者消费者模型,基于阻塞队列的生产者消费者模型的代码实现
linux·运维·服务器·开发语言·网络·c++·算法
Dxy12393102163 小时前
Python基于BERT的上下文纠错详解
开发语言·python·bert
风吹迎面入袖凉4 小时前
【Redis】Redisson的可重入锁原理
java·redis