博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
leetcode 628 Maximum Product of Three Numbers
阅读量:6147 次
发布时间:2019-06-21

本文共 1409 字,大约阅读时间需要 4 分钟。

题目详情

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

想法

  • 这道题最主要的是要考虑正负数的情况。
  • 如果全都是正数相乘比较大,就取三个最大值相乘即可。
  • 如果负数的绝对值比较大,我们可以取绝对值最大的两个负数参与相乘,最后比较一下两种算法的乘积哪个大。

解法一 时间复杂度O(n)

  • 这个解法写起来麻烦一点,判断条件比较多,但是时间复杂度为O(n)
public int maximumProduct(int[] nums) {        Integer max1 = Integer.MIN_VALUE;Integer max2 = max1;Integer max3 = max1;        Integer min1 = Integer.MAX_VALUE;Integer min2 = min1;                for(int num : nums){            if(num > max1){                max3 = max2;                max2 = max1;                max1 = num;            }else if(num > max2){                max3 = max2;                max2 = num;            }else if(num > max3){                max3 = num;            }                        if(num < min1){                min2 = min1;                min1 = num;            }else if(num < min2){                min2 = num;            }                    }                        return Math.max(max1*max2*max3, max1*min1*min2);    }

解法二 预排序

  • 先对数组进行预排序的算法比较简洁,但是时间复杂度为O(nlogn)
public int maximumProduct(int[] nums) {                 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 a > b ? a : b;    }

转载地址:http://vwqya.baihongyu.com/

你可能感兴趣的文章
Vue.js连接后台数据jsp页面  ̄▽ ̄
查看>>
关于程序的单元测试
查看>>
mysql内存优化
查看>>
都市求生日记第一篇
查看>>
Java集合---HashMap源码剖析
查看>>
SQL优化技巧
查看>>
thead 固定,tbody 超出滚动(附带改变滚动条样式)
查看>>
Dijkstra算法
查看>>
css 动画 和 响应式布局和兼容性
查看>>
csrf 跨站请求伪造相关以及django的中间件
查看>>
MySQL数据类型--与MySQL零距离接触2-11MySQL自动编号
查看>>
生日小助手源码运行的步骤
查看>>
Configuration python CGI in XAMPP in win-7
查看>>
bzoj 5006(洛谷 4547) [THUWC2017]Bipartite 随机二分图——期望DP
查看>>
CF 888E Maximum Subsequence——折半搜索
查看>>
欧几里德算法(辗转相除法)
查看>>
面试题1-----SVM和LR的异同
查看>>
MFC控件的SubclassDlgItem
查看>>
如何避免历史回退到登录页面
查看>>
《图解HTTP》1~53Page Web网络基础 HTTP协议 HTTP报文内的HTTP信息
查看>>