三個數的最大乘積

給定一個整型數組,在數組中找出由三個數組成的最大乘積,并輸出這個乘積。

  • 示例 1:
輸入: [1,2,3]
輸出: 6
  • 示例 2:
輸入: [1,2,3,4]
輸出: 24
  • 注意:

給定的整型數組長度范圍是[3,104],數組中所有的元素范圍是[-1000, 1000]
輸入的數組中任意三個數的乘積不會超出32位有符號整數的范圍。

  • 先排序
class Solution {
public:void quickSort(vector<int>& nums, int low, int high) {if (high <= low) {return;}int key = nums[low];int i = low;int j = high+1;while(true) {while(nums[++i] < key) {if (i == high) {break;}}while(nums[--j] > key) {if (j == low) {break;}}if (i >=j ) {break;}int temp = nums[i];nums[i] = nums[j];nums[j] = temp;}nums[low] = nums[j];nums[j] = key;quickSort(nums, low, j-1);quickSort(nums, j+1, high);}int maximumProduct(vector<int>& nums) {quickSort(nums, 0, nums.size()-1);return max(nums[nums.size()-1] * nums[nums.size()-2] * nums[nums.size()-3], nums[nums.size()-1] * nums[0] * nums[1]);}
};
  • 線性掃描
class Solution {
public:int maximumProduct(vector<int>& nums) {int min1 = INT_MAX, min2 = INT_MAX;int max1 = INT_MIN, max2 = INT_MIN, max3 = INT_MIN;for (const auto& num: nums) {if (num < min1) {min2 = min1;min1 = num;} else if (num < min2) {min2 = num;}if (num > max1) {max3 = max2;max2 = max1;max1 = num;} else if (num > max2) {max3 = max2;max2 = num;} else if (num > max3){max3 = num;}}return max(max1 * max2 * max3, max1 * min1 * min2);}
};

來源:力扣(LeetCode)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/375560.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/375560.shtml
英文地址,請注明出處:http://en.pswp.cn/news/375560.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

VB.NET 數組的定義 動態使用 多維數組

我們都知道在全部程序設計語言中數組都是一個非常重要的概念&#xff0c;數組的作用是同意程序猿用同一個名稱來引用多個變量&#xff0c;因此採用數組索引來區分這些變量。非常多情況下利用數組索引來設置一個循環&#xff0c;這樣就能夠高效地處理復雜的情況&#xff0c;因此…

web.xml 中的listener、 filter、servlet 加載順序

1&#xff1a;首先是context-param節點 2&#xff1a;接著配置和調用listeners 并開始監聽 3&#xff1a;然后配置和調用filters filters開始起作用 4&#xff1a;最后加載和初始化配置在load on startup的servlets轉載于:https://www.cnblogs.com/dwchenxj/p/4787717.html

這么多個月,我頭一次體驗用類的概念來寫驅動

原來感覺一樣是那么爽阿。。。快樂得不得了。。。轉載于:https://www.cnblogs.com/suanguade/p/4038190.html

設置Chrome忽略網站證書錯誤

本人在XP下使用Chrome。總是莫名其妙的提示整數錯誤&#xff0c;一部分https網站無法直接訪問。網上找了下&#xff0c;把解決思路記錄下來。 解決這個問題很簡單,只需要修改你平時用來啟動Chrome的快捷方式就可以忽略掉證書錯誤. 具體的操作方法是這樣的: 找到你的Chrome快捷方…

Android開發之合并文件的幾種方式

以下介紹合并文件的幾種方式&#xff0c;并通過合并amr文件來舉例介紹合并文件的詳細流程。amr格式的文件頭是6字節&#xff0c;所以在進行文件合并的時候要減去除第一個文件以外的其它文件的文件頭。 注意&#xff1a;不同文件的文件頭是不一樣的&#xff0c;所以在合并的時候…

數組中出現次數超過一半的數

數組中有一個數字出現的次數超過數組長度的一半&#xff0c;請找出這個數字。 你可以假設數組是非空的&#xff0c;并且給定的數組總是存在多數元素。 示例 1: 輸入: [1, 2, 3, 2, 2, 2, 5, 4, 2] 輸出: 2限制&#xff1a; 1 < 數組長度 < 50000class Solution { pub…

中國寒龍反網絡病毒聯盟核心小組:官方公告,近期本站將會發布各種編程技術視頻教程,詳情請點擊我們的以下公告!...

大家好&#xff0c;我是中國寒反網絡病毒聯盟官方客服&#xff01; 近期&#xff0c;本站將全面升級&#xff0c;本站發布各種編程視頻教程&#xff0c;包括C,c#以及VB&#xff0c;VB.net&#xff0c;E&#xff0c;等相關編程語言入門視頻教程&#xff0c;每天會定期更新視頻教…

javascript學習-原生javascript的小特效(多個運動效果整理)

以下代碼就不詳細解析了&#xff0c;在我之前的多個運動效果中已經解析好多次了&#xff0c;重復的地方這里就不說明了&#xff0c;有興趣的童鞋可以去看看之前的文章《原生javascript的小特效》 <!DOCTYPE HTML> <html lang"en-US"> <head> <m…

linux在指定目錄多個文件中搜索關鍵字

find 文件目錄 -name *.* -exec grep xxx {} -n\;# -n顯示行號find 文件目錄 -name *.* | xargs grep xxx -ngrep xxx 文件目錄 -Rngrep xxx find 文件目錄 -name *.*

$ npm install opencv ? 你試試?! 在windows環境下,使用node.js調用opencv攻略

博主之前寫過一篇文章《html5與EmguCV前后端實現——人臉識別篇》&#xff0c;敘述的是opencv和C#的故事。最近在公司服務器上更新了一套nodejs環境&#xff0c;早就聽聞npm上有opencv模塊&#xff0c;便欲部署之。然而opencv的部署似乎從來都不會那么順利...... 找模塊上https…

android學習——GestureDetector.OnGestureListener 詳解

Android Touch Screen 與傳統Click Touch Screen不同&#xff0c;會有一些手勢(Gesture)&#xff0c;例如Fling&#xff0c;Scroll等等。這些Gesture會使用戶體驗大大提升。Android中的Gesture識別(detector)是通過GestureDetector.OnGestureListener接口實現的。 首先&#xf…

關于安卓一鍵分享的,急求幫助!

問題描述現在要做一個項目&#xff0c;設置里面點擊一個按鈕就可以分享&#xff0c;有三個分享平臺&#xff0c;新浪微博&#xff0c;微信和微信朋友圈現在的問題是我要在三個平臺分享的內容不同&#xff0c;在新浪微博中分享的是一段文字敘述和一個網頁鏈接&#xff1b;而在微…

和可被 K 整除的子數組

給定一個整數數組 A&#xff0c;返回其中元素之和可被 K 整除的&#xff08;連續、非空&#xff09;子數組的數目。 示例&#xff1a; 輸入&#xff1a;A [4,5,0,-2,-3,1], K 5 輸出&#xff1a;7 解釋&#xff1a; 有 7 個子數組滿足其元素之和可被 K 5 整除&#xff1a;…

前端進階路線圖

CSS不能編程&#xff1f;用Less、Sass、Stylus、甚至直接用 Absurd&#xff0c;框架除了Bootstrap還有很多。JS寫多了很麻煩&#xff1f;jQuery。移動開發&#xff1f;Zepto.js。結構不好&#xff1f;找框架&#xff0c;Backbone.js是MVC&#xff0c;AngularJS和Ember.js是MVVM…

流媒體直播服務LSS

流媒體直播服務LSS posted on 2014-10-22 11:23 實驗室 閱讀(...) 評論(...) 編輯 收藏 轉載于:https://www.cnblogs.com/labs/p/4042641.html

Win7安裝vs2010失敗

提示&#xff1a; --------------------------------------------------------------------------------------------------------------------------------------- 解決方法&#xff1a;開始運行中regedit打開注冊表找到HKEY_LOCAL_MACHINE/System/CurrentControlSet/Control …

調光設備術語:調光曲線(轉)

源&#xff1a;調光設備術語&#xff1a;調光曲線 核心提示&#xff1a;調光曲線是調光設備重要的參數之一&#xff0c;它直接影響到了燈光輸出的效果&#xff0c;是數字化調光設備性能的體現。上面這句話包含了三點內容&#xff0c;我們逐條解析。 調光曲線是調光設備重要的參…

深入淺出理解QTimeLine類

網上找了下QTimeLIne類的介紹&#xff0c;要么就是代碼一貼自己看去&#xff0c;要么就是說不到重點&#xff0c;正巧自己項目遇到這個類&#xff0c;在這里寫一下&#xff0c;給需要的同學看下。 因為我最近需要有動畫方面配合時間間隔觸發QGraphicsView框架的需求&#xff0c…

0909編譯原理

1.編譯原理學什么&#xff1f; 編譯原理是計算機專業的一門重要專業課&#xff0c;旨在介紹編譯程序構造的一般原理和基本方法。內容包括語言和文法、詞法分析、語法分析、語法制導翻譯、中間代碼生成、存儲管理、代碼優化和目標代碼生成。 2.為什么學編譯原理&#xff1f; 這門…

何為動態綁定(轉)

動態綁定只是叫法不同&#xff0c;你可以理解為多態&#xff01;例如&#xff0c;有一個抽像fruit水果父類&#xff0c;其中定義了一個方法抽像eat方法&#xff0c;而apple繼承fruit并實現fruit的eat方法&#xff0c;而banana繼承fruit并實現fruit的eat方法&#xff0c;外部調用…