微信小程序开发之小程序架构篇的图解与分析
604
2022-09-04
628. Maximum Product of Three Numbers
Given an integer array, find three numbers whose product is maximum and output the maximum product.
Example 1:
Input: [1,2,3]Output: 6
Example 2:
Input: [1,2,3,4]Output: 24
Note: The length of the given array will be in range [3,104] and all elements are in the range [-1000, 1000]. Multiplication of any three numbers in the input won’t exceed the range of 32-bit signed integer.
思路: 求三个数的最大乘积,要考虑数值为正还是为负。首先可以利用Arrays.sort()进行排序,得到最大值。如果最大值为负值,则数组中所有的值都为负值,最大的乘积就是最后三位数字的乘积;如果最大值为正值,则数组中可能存在负值,若都为正值,最大乘积为最后三位的乘积,若存在负值,可能最大值为最大数与前两位的乘积。
public class Solution { public int maximumProduct(int[] nums) { if (nums == null || nums.length == 0) { return 0; } Arrays.sort(nums); int a = nums[nums.length - 1] * nums[nums.length - 2] * nums[nums.length - 3]; int b = nums[0] * nums[1] * nums[nums.length - 1]; return
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~