【LeetCode: 628. 三个数的最大乘积 + 排序 + 贪心】-LMLPHP

【LeetCode: 628. 三个数的最大乘积 + 排序 + 贪心】-LMLPHP

【LeetCode: 628. 三个数的最大乘积 + 排序 + 贪心】-LMLPHP

🚩 题目链接

⛲ 题目描述

给你一个整型数组 nums ,在数组中找出由三个数组成的最大乘积,并输出这个乘积。

示例 1:

输入:nums = [1,2,3]
输出:6
示例 2:

输入:nums = [1,2,3,4]
输出:24
示例 3:

输入:nums = [-1,-2,-3]
输出:-6

提示:

3 <= nums.length <= 104
-1000 <= nums[i] <= 1000

🌟 求解思路&实现代码&运行结果


⚡ 排序 + 贪心

🥦 求解思路
  1. 直接排序,最大的三个数的乘积可能是最大的三个数,也可能的最小的俩个数和最大的一个数的乘积,比较一下大小即可。
  2. 有了基本的思路,接下来我们就来通过代码来实现一下。
🥦 实现代码
class Solution {
    public int maximumProduct(int[] nums) {
        Arrays.sort(nums);
        int n = nums.length;
        return Math.max(nums[0] * nums[1] * nums[n - 1], nums[n - 3] * nums[n - 2] * nums[n - 1]);
    }
}
🥦 运行结果

【LeetCode: 628. 三个数的最大乘积 + 排序 + 贪心】-LMLPHP


💬 共勉

【LeetCode: 628. 三个数的最大乘积 + 排序 + 贪心】-LMLPHP

【LeetCode: 628. 三个数的最大乘积 + 排序 + 贪心】-LMLPHP

04-11 03:25