新股上市增資 IPO Leetcode #502 優先權佇列應用

更新於 2024/06/15閱讀時間約 5 分鐘

題目敘述 IPO

新企業準備上市增資,初始資本是w,可以參加k個專案。

每個專案的獲利和投入成本分別記錄在profits和capital陣列。

請問,在盡可能增資的情況下,最後最大的總資本是多少?


測試範例

Example 1:

Input: k = 2, w = 0, profits = [1,2,3], capital = [0,1,1]
Output: 4
Explanation: Since your initial capital is 0, you can only start the project indexed 0.
After finishing it you will obtain profit 1 and your capital becomes 1.
With capital 1, you can either start the project indexed 1 or the project indexed 2.
Since you can choose at most 2 projects, you need to finish the project indexed 2 to get the maximum capital.
Therefore, output the final maximized capital, which is 0 + 1 + 3 = 4.

參加第一個專案 總資本成長到1單位
參加第三個專案 總資本成長到4單位​

Example 2:

Input: k = 3, w = 0, profits = [1,2,3], capital = [0,1,2]
Output: 6

參加第一個專案 總資本成長到1單位
參加第三個專案 總資本成長到3單位​
參加第三個專案 總資本成長到6單位​

約束條件

Constraints:

  • 1 <= k <= 10^5

參數k值介於1~十萬之間。

  • 0 <= w <= 10^9

參數w值介於1~十億之間。

  • n == profits.length
  • n == capital.length

n代表專案的數目。

  • 1 <= n <= 10^5

最少一個專案,最多十萬個專案。

  • 0 <= profits[i] <= 10^4

每個專案的獲利最少0元,最多一萬元。

  • 0 <= capital[i] <= 10^9

每個專案的投入成本最少0元,最多十億元。


觀察

如何獲得最大資本?

有一個直覺的想法,在資金許可的情況下,盡可能投入回報收益最大的專案


演算法 盡可能投入回報收益最大的專案

先對專案排序,投入成本小的專案優先考慮。

接著用堆積去篩選出回報收益最大的專案,選擇前k個收益最大的專案

最後的總資本就是增資後的最大值。


程式碼 盡可能投入回報收益最大的專案

class Solution:
def findMaximizedCapital(self, k, W, Profits, Capital):

# heap for project profit
heap = []
projects = sorted(zip(Profits, Capital), key=lambda p: p[1])
i = 0

# Pick k projects at most.
for _ in range(k):

# Push available projects into heap
while i < len(projects) and projects[i][1] <= W:
heapq.heappush(heap, -projects[i][0])
i += 1

# Pick best project with maximal profit.
if heap:
W += abs( heapq.heappop(heap) )

# Maximal capital we have
return W

複雜度分析

時間複雜度: O( (k+n) log n)

排序前處理耗費O( n log n)

for loop挑選前k個最佳的專案耗費O( k log n)

空間複雜度: O(n)

維護一個minHeap,heap最大可能多達n個專案,所需空間為O(n)


關鍵知識點

在資金許可的情況下,盡可能投入回報收益最大的專案

用Priority Queue,在實作中,就是heap,去挑選前k個可參與且收益最高的專案。


Reference

[1] IPO - LeetCode





avatar-img
90會員
425內容數
由有業界實戰經驗的演算法工程師, 手把手教你建立解題的框架, 一步步寫出高效、清晰易懂的解題答案。 著重在讓讀者啟發思考、理解演算法,熟悉常見的演算法模板。 深入淺出地介紹題目背後所使用的演算法意義,融會貫通演算法與資料結構的應用。 在幾個經典的題目融入一道題目的多種解法,或者同一招解不同的題目,擴展廣度,並加深印象。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
題目敘述 Triangle 題目會給我們一個三角形的二維陣列triangle ,每個元素分別代表每個格子的成本,請問我們從最頂端到底部的下墜路徑的最小成本總和是多少? 每次下墜到下一排的時候,可以有兩種選擇: 1.往左下方的格子點移動。 2.往右下方的格子點移動。 測試範例 Examp
題目敘述 Minimum Increment to Make Array Unique 給定一個整數陣列,每回合可以任意挑一個數字進行+1的加法操作。 請問最少需要多少次的+1加法操作,才能讓每個數字都相異?
Paint House 題目會給定一個成本陣列costs,分別代表每棟房屋粉刷成紅色、藍色、綠色的成本。 請問粉刷所有房屋的最小成本是多少,而且相鄰的房屋不可同一種顏色。
題目敘述 Longest Arithmetic Subsequence of Given Difference 給定一個整數陣列nums,請找出給定公差difference的最長的等差數列的長度是多少?
題目敘述 Solving Questions With Brainpower 給定一個測驗題陣列,每個欄位都是一個pair, 分別記錄測驗題做完可以得到的分數,和需要的冷卻時間 (也就是會有一段時間不能作答接下來的題目)。 請問在最佳的答題策略下,最多可以獲得多少分數?
題目敘述 Sort Colors 給定一個色彩陣列,裡面的顏色包含0紅色,1白色,2藍色。 要求我們透過in-place操作,把色彩陣列依序從左到右排好, 依序出現的是紅色、白色、藍色。
題目敘述 Triangle 題目會給我們一個三角形的二維陣列triangle ,每個元素分別代表每個格子的成本,請問我們從最頂端到底部的下墜路徑的最小成本總和是多少? 每次下墜到下一排的時候,可以有兩種選擇: 1.往左下方的格子點移動。 2.往右下方的格子點移動。 測試範例 Examp
題目敘述 Minimum Increment to Make Array Unique 給定一個整數陣列,每回合可以任意挑一個數字進行+1的加法操作。 請問最少需要多少次的+1加法操作,才能讓每個數字都相異?
Paint House 題目會給定一個成本陣列costs,分別代表每棟房屋粉刷成紅色、藍色、綠色的成本。 請問粉刷所有房屋的最小成本是多少,而且相鄰的房屋不可同一種顏色。
題目敘述 Longest Arithmetic Subsequence of Given Difference 給定一個整數陣列nums,請找出給定公差difference的最長的等差數列的長度是多少?
題目敘述 Solving Questions With Brainpower 給定一個測驗題陣列,每個欄位都是一個pair, 分別記錄測驗題做完可以得到的分數,和需要的冷卻時間 (也就是會有一段時間不能作答接下來的題目)。 請問在最佳的答題策略下,最多可以獲得多少分數?
題目敘述 Sort Colors 給定一個色彩陣列,裡面的顏色包含0紅色,1白色,2藍色。 要求我們透過in-place操作,把色彩陣列依序從左到右排好, 依序出現的是紅色、白色、藍色。
你可能也想看
Google News 追蹤
Thumbnail
*合作聲明與警語: 本文係由國泰世華銀行邀稿。 證券服務係由國泰世華銀行辦理共同行銷證券經紀開戶業務,定期定額(股)服務由國泰綜合證券提供。   剛出社會的時候,很常在各種 Podcast 或 YouTube 甚至是在朋友間聊天,都會聽到各種市場動態、理財話題,像是:聯準會降息或是近期哪些科
Thumbnail
​投資理財內容聲明 文內如有投資理財相關經驗、知識、資訊等內容,皆為作者個人分享行為。 有價證券、指數與衍生性商品之數據資料,僅供輔助說明之用,不代表創作者投資決策之推介及建議。 閱讀同時,請審慎思考自身條件及自我決策,並應有為決策負責之事前認知。 希望您能從這些分享內容汲取投資養份,養成獨
Thumbnail
圖:經濟部部長王美花與傳統市場攤商合影留念,展現了共同追求繁榮的決心,部長王美花致力於促進傳統市場及夜市商業發展。這張照片象徵著政府與傳統市場攤商攜手前進,共同創造經濟發展的新機遇。 【李婉如/ 報導】經濟部今(20)日舉辦「榮市聚金~2023臺灣五星集~優良市集暨樂活名攤頒獎典禮」,今年榮獲
Thumbnail
SpaceX的Starlink衛星網路服務一直是他們的核心業務之一,通過近年來的積極擴展,最近終於實現了現金流平衡,未來有望獨立上市。 SpaceX本身在2022年已經實現了現金流的盈餘,並在2023年繼續保持盈利。至於旗下的Starlink衛星網路服務,Elon Musk最近在X上透露,它終
Thumbnail
比別人走快一步 為未來 ai 概念股新股上市 ipo做好準備 Ai 概念股揀股心法 (根據現在情況~), 我們投資者,不論金主股民在選擇所有新科技概念股票的時候,都會面對 2個問題。 第1個問題就很簡單直接,新科技最後會否賺錢,股價升定跌 ? 第 2個問題就接著第 1個問題,假設新科技真的能夠賺錢,
Thumbnail
隨著《星際異攻隊3》(Guardians of the Galaxy Vol. 3)即將於五月份上映,樂高也先釋出了三款專屬的盒組。
Thumbnail
星宇航空(2646)表示:「星宇準備好了!拚明年營收50億元,達損益兩平,最快2024年上市。」
Thumbnail
【生活裡的酷科學】系列,​將為小腦袋瓜裡的有趣提問提供解答,​生活裡的觀察和發現,​原來都跟科學有關係!?Wow!Amazing!​
大家的航海王、貨櫃三雄之一的陽明在五月股東會通過了現金增資案,決定以詢價圈購的方式辦理現金增資,最近在7月5日公告了開始辦理詢價圈購到7月7日為止,究竟詢價圈購是什麼?是如何運作的呢?投資人該怎麼參與呢?
Thumbnail
2020的關鍵字是:信仰。相信我就對了,從Tesla、比特幣再到SPAC IPO,滿滿的都是信仰的故事。資本市場在疫情熔斷崩潰後美國聯準會天量寬鬆灌注流動性,和政府援助刺激撒錢Robinhood散戶進場的情形下大熱,出現的現象,是一波又一波創紀錄的IPO新股上市,和空白支票公司SPAC持續受到追捧。
這個世界無奇不有,驚喜多,驚嚇更多,原本可以星期四正式上市的螞蟻金服(6688),居然突然被煞停,首先是在晚上突然看到一個訊息:「上交所發佈關於暫緩螞蟻科技集團股份有限公司科創板上市的決定。」然後立即引起熱烈的討論,因為螞蟻金服是A+H股同步上市的,現在突然說A股暫緩上市,H股不會還是如期上市吧?如
Thumbnail
*合作聲明與警語: 本文係由國泰世華銀行邀稿。 證券服務係由國泰世華銀行辦理共同行銷證券經紀開戶業務,定期定額(股)服務由國泰綜合證券提供。   剛出社會的時候,很常在各種 Podcast 或 YouTube 甚至是在朋友間聊天,都會聽到各種市場動態、理財話題,像是:聯準會降息或是近期哪些科
Thumbnail
​投資理財內容聲明 文內如有投資理財相關經驗、知識、資訊等內容,皆為作者個人分享行為。 有價證券、指數與衍生性商品之數據資料,僅供輔助說明之用,不代表創作者投資決策之推介及建議。 閱讀同時,請審慎思考自身條件及自我決策,並應有為決策負責之事前認知。 希望您能從這些分享內容汲取投資養份,養成獨
Thumbnail
圖:經濟部部長王美花與傳統市場攤商合影留念,展現了共同追求繁榮的決心,部長王美花致力於促進傳統市場及夜市商業發展。這張照片象徵著政府與傳統市場攤商攜手前進,共同創造經濟發展的新機遇。 【李婉如/ 報導】經濟部今(20)日舉辦「榮市聚金~2023臺灣五星集~優良市集暨樂活名攤頒獎典禮」,今年榮獲
Thumbnail
SpaceX的Starlink衛星網路服務一直是他們的核心業務之一,通過近年來的積極擴展,最近終於實現了現金流平衡,未來有望獨立上市。 SpaceX本身在2022年已經實現了現金流的盈餘,並在2023年繼續保持盈利。至於旗下的Starlink衛星網路服務,Elon Musk最近在X上透露,它終
Thumbnail
比別人走快一步 為未來 ai 概念股新股上市 ipo做好準備 Ai 概念股揀股心法 (根據現在情況~), 我們投資者,不論金主股民在選擇所有新科技概念股票的時候,都會面對 2個問題。 第1個問題就很簡單直接,新科技最後會否賺錢,股價升定跌 ? 第 2個問題就接著第 1個問題,假設新科技真的能夠賺錢,
Thumbnail
隨著《星際異攻隊3》(Guardians of the Galaxy Vol. 3)即將於五月份上映,樂高也先釋出了三款專屬的盒組。
Thumbnail
星宇航空(2646)表示:「星宇準備好了!拚明年營收50億元,達損益兩平,最快2024年上市。」
Thumbnail
【生活裡的酷科學】系列,​將為小腦袋瓜裡的有趣提問提供解答,​生活裡的觀察和發現,​原來都跟科學有關係!?Wow!Amazing!​
大家的航海王、貨櫃三雄之一的陽明在五月股東會通過了現金增資案,決定以詢價圈購的方式辦理現金增資,最近在7月5日公告了開始辦理詢價圈購到7月7日為止,究竟詢價圈購是什麼?是如何運作的呢?投資人該怎麼參與呢?
Thumbnail
2020的關鍵字是:信仰。相信我就對了,從Tesla、比特幣再到SPAC IPO,滿滿的都是信仰的故事。資本市場在疫情熔斷崩潰後美國聯準會天量寬鬆灌注流動性,和政府援助刺激撒錢Robinhood散戶進場的情形下大熱,出現的現象,是一波又一波創紀錄的IPO新股上市,和空白支票公司SPAC持續受到追捧。
這個世界無奇不有,驚喜多,驚嚇更多,原本可以星期四正式上市的螞蟻金服(6688),居然突然被煞停,首先是在晚上突然看到一個訊息:「上交所發佈關於暫緩螞蟻科技集團股份有限公司科創板上市的決定。」然後立即引起熱烈的討論,因為螞蟻金服是A+H股同步上市的,現在突然說A股暫緩上市,H股不會還是如期上市吧?如