買賣股票的最佳時機--js 算法

一、買賣股票的最佳時機

給定一個數組 prices ,它的第 i 個元素 prices[i] 表示一支給定股票第 i 天的價格。你只能選擇 某一天 買入這只股票,并選擇在 未來的某一個不同的日子 賣出該股票。設計一個算法來計算你所能獲取的最大利潤。返回你可以從這筆交易中獲取的最大利潤。如果你不能獲取任何利潤,返回 0 ;

貪心算法:
每次發現更低價格立即更新買入點(minPrice)
每次發現更高利潤立即更新賣出收益(maxProfit)

/*** 計算股票買賣的最大利潤(單次交易)* @param {number[]} prices - 股票每日價格數組* @returns {number} 最大利潤(無利潤時返回0)*/
function maxProfit(prices) {// 邊界條件const len = prices.length || 0;if (len < 2) return 0;// 初始化歷史最低價為第一天值let minPrice = prices[0];// 初始化最大利潤為0(默認無利潤)let maxProfit = 0;// 單次遍歷所有價格點(從第二天開始)for (let i = 1; i < len; i++) {const currentPrice = prices[i];// 情況1:發現新的歷史最低價if (currentPrice < minPrice) {minPrice = currentPrice; // 更新歷史最低價// 情況2:當前價格高于歷史最低價,計算潛在利潤} else if (currentPrice - minPrice > maxProfit) {// 若當前利潤超過歷史最大利潤則更新maxProfit = currentPrice - minPrice;}/* 注意:無需處理其他情況(如當前利潤小于歷史最大利潤)因為此時只需維持已有的maxProfit值即可 */}// 返回整個遍歷過程中發現的最大利潤return maxProfit;
}

算法說明:
核心思路:單次遍歷數組,動態追蹤歷史最低價,并計算當前價格與歷史最低價的差值(潛在利潤)
關鍵變量
minPrice:記錄遍歷過程中遇到的最低價格(初始設為最大安全整數)
maxProfit:記錄當前最大利潤(初始為0)
遍歷過程
遇到更低價格時更新 minPrice
遇到更高價格時計算利潤,并更新 maxProfit
邊界處理:若所有價格遞減(無利潤),直接返回初始值0。

復雜度分析
時間復雜度 O(n):僅需遍歷數組一次
空間復雜度 O(1):僅使用兩個常量變量

二、買賣股票的最佳時機Ⅱ

給你一個整數數組 prices ,其中 prices[i] 表示某支股票第 i 天的價格。在每一天,你可以決定是否購買和/或出售股票。你在任何時候 最多 只能持有 一股 股票。你也可以先購買,然后在 同一天 出售。返回 你能獲得的 最大 利潤 。

貪心算法:
捕捉所有上漲波段

/*** 計算股票買賣的最大利潤(單次交易)* @param {number[]} prices - 股票每日價格數組* @returns {number} 最大利潤(無利潤時返回0)*/
function maxProfit(prices) { const len = prices.length || 0;if (len < 2) return 0;let maxProfit = 0;// 遍歷從第二天開始的所有價格for (let i = 1; i < len; i++) {const curPrice = prices[i]; // 第i天價格const prePrice = prices[i-1]; // 第i-1天價格if (curPrice > prePrice) maxProfit += (curPrice - prePrice);};return maxProfit;
}

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

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

相關文章

C#基礎(WndProc)

WndProc 是操作系統與你的程序“對話”的通道??。當用戶點擊鼠標、按下鍵盤&#xff0c;或系統事件&#xff08;如窗口移動&#xff09;發生時&#xff0c;Windows 會將這些事件打包成“消息”&#xff0c;發送給你的窗口&#xff0c;而 WndProc 就是接收和處理這些消息的函數…

記錄一個 Linux中腳本無法執行的問題

問題描述&#xff1a; 在本地的window系統傳的云服務器上一個.sh結尾的安裝Java環境的腳本 上傳到云服務器后&#xff0c;使用命令賦予執行權限 chmod x 文件名然后看一下這個腳本變綠了就可以了 然后開始嘗試執行 ./腳本名 然后就報錯了 然后開始排查問題 1.檢查并修復 She…

Iceberg在圖靈落地應用

導讀 百度MEG上一代大數據產品存在平臺分散、易用性差等問題&#xff0c;導致開發效率低下、學習成本高&#xff0c;業務需求響應遲緩。為了解決這些問題&#xff0c;百度MEG內部開發了圖靈3.0生態系統&#xff0c;包括Turing Data Engine(TDE)計算&存儲引擎、Turing Data…

FPGA設計的用戶約束

FPGA設計的用戶約束 文章目錄 FPGA設計的用戶約束FPGA設計的用戶約束綜合約束管腳約束位置約束時序約束小總結 FPGA設計的用戶約束 至此&#xff0c;HDL到門級網表的轉化已經完成&#xff0c;對于編譯器來說&#xff0c;下一步的任務就是要將門級網表轉換并映射到具體的FPGA硬…

Spring 生態創新應用:微服務架構設計與前沿技術融合實踐

在數字化轉型的深水區&#xff0c;企業級應用正面臨從 “單體架構” 向 “分布式智能架構” 的根本性躍遷。Spring 生態以其二十年技術沉淀形成的生態壁壘&#xff0c;已成為支撐這場變革的核心基礎設施。從 2002 年 Rod Johnson 發布《Expert One-on-One J2EE Design and Deve…

車牌識別與標注:基于百度OCR與OpenCV的實現(一)

車牌識別與標注&#xff1a;基于百度OCR與OpenCV的實現 在計算機視覺領域&#xff0c;車牌識別是一項極具實用價值的技術&#xff0c;廣泛應用于交通監控、智能停車場管理等領域。本文將介紹如何在macOS系統下&#xff0c;利用百度OCR API進行車牌識別&#xff0c;并結合OpenC…

【系統分析師】2021年真題:論文及解題思路

文章目錄 試題一&#xff1a;論面向對象的信息系統分析方法試題二&#xff1a;論靜態測試方法及其應用試題三&#xff1a;論富互聯網應用的客戶端開發技術試題四&#xff1a;論DevSecOps技術及其應用 試題一&#xff1a;論面向對象的信息系統分析方法 信息系統分析是信息系統生…

OFA-PT:統一多模態預訓練模型的Prompt微調

摘要 Prompt微調已成為模型微調的新范式&#xff0c;并在自然語言預訓練甚至視覺預訓練中取得了成功。參數高效的Prompt微調方法通過優化soft embedding并保持預訓練模型凍結&#xff0c;在計算成本低和幾乎無性能損失方面展現出優勢。在本研究中&#xff0c;我們探索了Prompt…

【硬核數學】2.5 “價值標尺”-損失函數:信息論如何設計深度學習的損失函數《從零構建機器學習、深度學習到LLM的數學認知》

歡迎來到本系列硬核數學之旅的第十篇&#xff0c;也是我們對經典數學領域進行深度學習“升級”的最后一站。我們已經擁有了強大的模型架構&#xff08;基于張量&#xff09;、高效的學習引擎&#xff08;反向傳播&#xff09;和智能的優化策略&#xff08;Adam等&#xff09;。…

雷卯針對靈眸科技EASY EAI nano RV1126 開發板防雷防靜電方案

一、應用場景 1. 人臉檢測 2. 人臉識別 3. 安全帽檢測 4. 人員檢測 5. OCR文字識別 6. 人頭檢測 7. 表情神態識別 8. 人體骨骼點識別 9. 火焰檢測 10. 人臉姿態估計 11. 人手檢測 12. 車輛檢測 13. 二維碼識別 二、 功能概述 1 CPU 四核ARM Cortex-A71.5GHz 2 …

【記錄】Ubuntu|Ubuntu服務器掛載新的硬盤的流程(開機自動掛載)

簡而言之&#xff0c;看這張圖片就好&#xff08;可以存一下&#xff0c;注意掛載點/data可以自定義&#xff0c;掛載硬盤的位置/dev/sdb要改成步驟1中檢查的時候查到的那個位置&#xff0c;不過這個圖的自動掛載漏了UUID&#xff0c;可以通過blkid指令查找&#xff09;&#x…

六、軟件操作手冊

建議在飛書平臺閱讀此文。 我將沿著初來乍到的用戶的瀏覽路徑介紹“諍略參謀”應用。 目錄 一、用戶信息1.1 注冊、登錄、自動登錄、忘記密碼、修改用戶名、修改密碼、退出登錄與個性化設置1.2 認識主界面與任務系統1.3 語義審查、Knowledge Cutoff 審查1.4 重要內容未保存提醒…

電腦鍵盤不能打字了怎么解決 查看恢復方法

電腦鍵盤打不了字&#xff0c;這是我們電腦使用過程中&#xff0c;偶爾會遇到的電腦故障問題。一般來說&#xff0c;電腦鍵盤打不出字&#xff0c;可能是硬件故障、驅動問題或系統設置錯誤等多種原因引起。本文將詳細介紹一些常見的原因和解決方法&#xff0c;幫助用戶恢復正常…

基于STM32的土豆種植自動化灌溉系統設計與實現

?? 項目簡介 隨著農業現代化發展及水資源短缺問題日益突出,傳統土豆種植方式在澆灌效率與用水科學性方面暴露出諸多問題。本文基于STM32F103C8T6微控制器,設計并實現了一種智能化的土豆種植自動灌溉系統,集成多種環境傳感器(溫濕度、土壤濕度、光照)、控制設備(水泵、…

第8篇:Gin錯誤處理——讓你的應用更健壯

作者:GO兔 博客:https://luckxgo.cn 分享大家都看得懂的博客 引言 在Web應用開發中&#xff0c;錯誤處理是保證系統穩定性和用戶體驗的關鍵環節。Gin作為高性能的Go Web框架&#xff0c;提供了靈活的錯誤處理機制&#xff0c;但許多開發者在實際項目中仍會遇到錯誤處理混亂、異…

【PyCharm】Python安裝路徑查找

PyCharm應用筆記 第一章 Python安裝路徑查找 文章目錄 PyCharm應用筆記前言一、電腦設置查找二、資源管理器查找 前言 本文主要介紹幾種Python安裝路徑查找的方法。 一、電腦設置查找 簡述過程&#xff1a;設置》應用》安裝的應用》搜索框輸入Python。 注&#xff1a;電腦使用…

數據結構:遞歸:漢諾塔問題(Tower of Hanoi)

目錄 問題描述 第一性原理分析 代碼實現 第一步&#xff1a;明確函數要干什么 第二步&#xff1a;寫好遞歸的“結束條件” 第三步&#xff1a;寫遞歸步驟 &#x1f333; 遞歸調用樹 &#x1f50d;復雜度分析 時間復雜度&#xff1a;T(n) 2^n - 1 空間復雜度分析 問題描…

synetworkflowopenrestydpdk

一.skynet 1. Skynet 的核心架構是什么&#xff1f;簡述其進程與服務模型。 Skynet 采用多進程多服務架構。主進程負責管理和監控&#xff0c;多個工作進程&#xff08;worker&#xff09;負責實際服務運行。每個服務&#xff08;service&#xff09;是一個獨立的 Lua 虛擬機&…

【甲方安全視角】安全防御體系建設

文章目錄 前言一、云安全防護能力第一階段:搭建安全防護設施第二階段:安全防護設施的精細化運營第三階段:安全運營周報輸出二、IT安全防護能力(一)辦公網安全設施建設(二)辦公網安全運營三、基礎安全防護能力(一)物理安全(二)運維安全(三)安全應急響應四、總結前言…

計算機組成原理與體系結構-實驗一 進位加法器(Proteus 8.15)

目錄 一、實驗目的 二、實驗內容 三、實驗器件 四、實驗原理 4.1 行波進位加法器 4.2 先行進位加法器 4.3 選擇進位加法器&#xff08;嘗試猜測原理&#xff09; 五、實驗步驟與思考題 一、實驗目的 1、了解半加器和全加器的電路結構。 2、掌握串行進位加法器和并行進…