技術問答
技術文章
iT 徵才
Tag
聊天室
2025 鐵人賽
登入/註冊
問答
文章
Tag
邦友
鐵人賽
搜尋
2025 iThome 鐵人賽
DAY
12
0
自我挑戰組
從零開始學習LeetCode
系列 第
12
篇
Day 12:Best Time to Buy and Sell Stock
17th鐵人賽
pinggg
2025-09-26 21:53:37
70 瀏覽
分享至
題目:給定一個整數陣列 prices,其中第 i 個元素代表股票在第 i 天的價格。
你只能 選擇一天買入,並且 選擇未來某一天賣出,求最大獲利。
如果無法獲利,回傳 0。
解法一
列舉所有買賣組合
大數據會超時
註解:
雙層迴圈,嘗試所有「買入、賣出」組合
記錄最大獲利
理解:
就像模擬「所有可能的買賣組合」,最後挑一個最賺的
解法二
記錄最低價 + 計算獲利
效率最高
註解:
min_price:用來追蹤目前最低的買入價
每次走訪 price,計算「今天賣出」能不能刷新最大獲利
時間複雜度:O(n),只需一次遍歷
理解:
就像每天觀察股價,先記住歷史最低價,再看今天賣出的話能賺多少
解法三
用陣列記錄每天最大獲利
本質和單次遍歷相同,但更偏向「每天更新最佳答案」的寫法
註解:
dp[i]:第 i 天的最大獲利
每天更新「歷史最低價」與「目前最大獲利」
本質上和方法二一樣,但寫法更符合 DP 思維
理解:
就像每天記錄「到今天為止的最佳交易結果」,一步一步累積出答案
留言
追蹤
檢舉
上一篇
Day 11 Intersection of Two Arrays II
下一篇
Day 13:Best Time to Buy and Sell Stock II
系列文
從零開始學習LeetCode
共
30
篇
目錄
RSS系列文
訂閱系列文
0
人訂閱
26
Day 26 Valid Parentheses
27
Day 27 Longest Common Prefix
28
Day 28 Valid Palindrome
29
Day29 First Unique Character in a String
30
Day30 總結
完整目錄
熱門推薦
{{ item.subject }}
{{ item.channelVendor }}
|
{{ item.webinarstarted }}
|
{{ formatDate(item.duration) }}
直播中
立即報名
尚未有邦友留言
立即登入留言
iThome鐵人賽
參賽組數
902
組
團體組數
37
組
累計文章數
19838
篇
完賽人數
529
人
看影片追技術
看更多
{{ item.subject }}
{{ item.channelVendor }}
|
{{ formatDate(item.duration) }}
直播中
熱門tag
看更多
15th鐵人賽
16th鐵人賽
13th鐵人賽
14th鐵人賽
17th鐵人賽
12th鐵人賽
11th鐵人賽
鐵人賽
2019鐵人賽
javascript
2018鐵人賽
python
2017鐵人賽
windows
php
c#
linux
windows server
css
react
熱門問題
FortiGate 的VLAN Switch問題
源碼檢測稽核會不會超耗時
內控內稽的作業流程圖.請問哪裡有設備工程業的
你們都在哪裡購買SSL
WIN SERVER 出現錯誤LOG
VMware上的虛擬機多了一個VMDK的硬碟在增長
浮水印在PDF上沒有辦法顯示
DOCKER問題請教
越南 Oracle EBS 輔導顧問公司
熱門回答
你們都在哪裡購買SSL
源碼檢測稽核會不會超耗時
FortiGate 的VLAN Switch問題
內控內稽的作業流程圖.請問哪裡有設備工程業的
WIN SERVER 出現錯誤LOG
熱門文章
Google 暗網監控 暗網報告
[實作] 不用買貴森森的 Vector!我用 Python 自製了一套 J1939 CAN Bus 解碼器
資料視覺化工具比較全攻略:選出最懂你的可視化平台
別找了!最全資料視覺化配色指南在這
掌握財務命脈:揭祕16個常用的財務指標
IT邦幫忙
×
標記使用者
輸入對方的帳號或暱稱
Loading
找不到結果。
標記
{{ result.label }}
{{ result.account }}