三个数的最大乘积Java
文章发布较早,内容可能过时,阅读注意甄别。
# 题目
给你一个整型数组 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
# 思路
Arrays.sort
# 解法
class Solution {
public int maximumProduct(int[] nums) {
int n = nums.length;
Arrays.sort(nums);
return Math.max(nums[0]*nums[1]*nums[n - 1], nums[n - 1]*nums[n - 2]*nums[n - 3]);
}
}
1
2
3
4
5
6
7
8
9
10
2
3
4
5
6
7
8
9
10
# 总结
- 分析出几种情况,然后分别对各个情况实现