[LeetCode] 628. 三个数的最大乘积(Java)
1.题目描述
给你一个整型数组 nums
,在数组中找出由三个数组成的最大乘积,并输出这个乘积。
示例 1:
输入:nums = [1,2,3]
输出:6
示例 2:
输入:nums = [1,2,3,4]
输出:24
示例 3:
输入:nums = [-1,-2,-3]
输出:-6
2.解题思路
先排序,其最大结果有两种,要不然是负负得正再乘以最大值,要不然三个大值相乘。
3.解法
class Solution {
public int maximumProduct(int[] nums) {
int len = nums.length;
if (len == 3){
return nums[0] * nums[1] * nums[2];
}
Arrays.sort(nums);
return Math.max(nums[0] * nums[1] * nums[len - 1], nums[len - 1] * nums[len - 2] * nums[len - 3] );
}
}
4.技能点
无。