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

更新於 發佈於 閱讀時間約 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
留言分享你的想法!
👏🥤🍨🧋😚
小松鼠-avatar-img
發文者
2024/06/15
林燃(創作小說家) 神仙姐姐喝長島冰茶🍹看夜景🌕⭐☄
avatar-img
小松鼠的演算法樂園
95會員
427內容數
由有業界實戰經驗的演算法工程師, 手把手教你建立解題的框架, 一步步寫出高效、清晰易懂的解題答案。 著重在讓讀者啟發思考、理解演算法,熟悉常見的演算法模板。 深入淺出地介紹題目背後所使用的演算法意義,融會貫通演算法與資料結構的應用。 在幾個經典的題目融入一道題目的多種解法,或者同一招解不同的題目,擴展廣度,並加深印象。
2024/10/06
題目敘述 Rank Transform of an Array 給定一個陣列arr,請根據數字的大小給予序號,序號值介於1~len( set(arr) )之間。 最大的數字給予最大的序號。 次大的數字給予次大的序號。 ...依此類推 最小的數字給予最小的序號1。
Thumbnail
2024/10/06
題目敘述 Rank Transform of an Array 給定一個陣列arr,請根據數字的大小給予序號,序號值介於1~len( set(arr) )之間。 最大的數字給予最大的序號。 次大的數字給予次大的序號。 ...依此類推 最小的數字給予最小的序號1。
Thumbnail
2024/10/01
題目敘述 Check If Array Pairs Are Divisible by k 給定一個長度為偶數的整數陣列arr,和一個整數k 。 我們想把陣列元素兩兩一組組成pair,使得每個pair的總和可以被k整除。 如果做得到,返回True。 如果不行,返回False。
Thumbnail
2024/10/01
題目敘述 Check If Array Pairs Are Divisible by k 給定一個長度為偶數的整數陣列arr,和一個整數k 。 我們想把陣列元素兩兩一組組成pair,使得每個pair的總和可以被k整除。 如果做得到,返回True。 如果不行,返回False。
Thumbnail
2024/09/29
My Calendar II 給定一個行事曆的class定義和行程安排的介面。 請完成下列function 1.建構子MyCalendarTwo() 2.boolean book(int start, int end) 在行事曆加入一項新行程,起始時間為start, 結束時間為end。
Thumbnail
2024/09/29
My Calendar II 給定一個行事曆的class定義和行程安排的介面。 請完成下列function 1.建構子MyCalendarTwo() 2.boolean book(int start, int end) 在行事曆加入一項新行程,起始時間為start, 結束時間為end。
Thumbnail
看更多
你可能也想看
Thumbnail
每年4月、5月都是最多稅要繳的月份,當然大部份的人都是有機會繳到「綜合所得稅」,只是相當相當多人還不知道,原來繳給政府的稅!可以透過一些有活動的銀行信用卡或電子支付來繳,從繳費中賺一點點小確幸!就是賺個1%~2%大家也是很開心的,因為你們把沒回饋變成有回饋,就是用卡的最高境界 所得稅線上申報
Thumbnail
每年4月、5月都是最多稅要繳的月份,當然大部份的人都是有機會繳到「綜合所得稅」,只是相當相當多人還不知道,原來繳給政府的稅!可以透過一些有活動的銀行信用卡或電子支付來繳,從繳費中賺一點點小確幸!就是賺個1%~2%大家也是很開心的,因為你們把沒回饋變成有回饋,就是用卡的最高境界 所得稅線上申報
Thumbnail
全球科技產業的焦點,AKA 全村的希望 NVIDIA,於五月底正式發布了他們在今年 2025 第一季的財報 (輝達內部財務年度為 2026 Q1,實際日曆期間為今年二到四月),交出了打敗了市場預期的成績單。然而,在銷售持續高速成長的同時,川普政府加大對於中國的晶片管制......
Thumbnail
全球科技產業的焦點,AKA 全村的希望 NVIDIA,於五月底正式發布了他們在今年 2025 第一季的財報 (輝達內部財務年度為 2026 Q1,實際日曆期間為今年二到四月),交出了打敗了市場預期的成績單。然而,在銷售持續高速成長的同時,川普政府加大對於中國的晶片管制......
Thumbnail
重點摘要: 6 月繼續維持基準利率不變,強調維持高利率主因為關稅 點陣圖表現略為鷹派,收斂 2026、2027 年降息預期 SEP 連續 2 季下修 GDP、上修通膨預測值 --- 1.繼續維持利率不變,強調需要維持高利率是因為關稅: 聯準會 (Fed) 召開 6 月利率會議
Thumbnail
重點摘要: 6 月繼續維持基準利率不變,強調維持高利率主因為關稅 點陣圖表現略為鷹派,收斂 2026、2027 年降息預期 SEP 連續 2 季下修 GDP、上修通膨預測值 --- 1.繼續維持利率不變,強調需要維持高利率是因為關稅: 聯準會 (Fed) 召開 6 月利率會議
Thumbnail
題目敘述 IPO 新企業準備上市增資,初始資本是w,可以參加k個專案。 每個專案的獲利和投入成本分別記錄在profits和capital陣列。 請問,在盡可能增資的情況下,最後最大的總資本是多少?
Thumbnail
題目敘述 IPO 新企業準備上市增資,初始資本是w,可以參加k個專案。 每個專案的獲利和投入成本分別記錄在profits和capital陣列。 請問,在盡可能增資的情況下,最後最大的總資本是多少?
Thumbnail
▲資本額:5.91 ▲股價:229.5 ▲評分標準(滿分4分):3.33分 營收2、營益4、稅後淨利3、EPS4、存貨4、自由現金流量3 ▲預估今年營收:32.3億
Thumbnail
▲資本額:5.91 ▲股價:229.5 ▲評分標準(滿分4分):3.33分 營收2、營益4、稅後淨利3、EPS4、存貨4、自由現金流量3 ▲預估今年營收:32.3億
Thumbnail
散熱持股皆在減碼後持續噴出,不要笑。 接下來持續關注個股新聞以及是否有別的標的符合策略的 奇鋐去年Q4 EPS 4.36元 與全年14.11元同刷新高 資金利用率約80%
Thumbnail
散熱持股皆在減碼後持續噴出,不要笑。 接下來持續關注個股新聞以及是否有別的標的符合策略的 奇鋐去年Q4 EPS 4.36元 與全年14.11元同刷新高 資金利用率約80%
Thumbnail
2024年01月上市上櫃公司營收數據統計暨創歷史新高公司清單 1月上市上櫃公司營收成長情況與營收創新高的公司清單(59家),請到這裡下載:https://miller.pse.is
Thumbnail
2024年01月上市上櫃公司營收數據統計暨創歷史新高公司清單 1月上市上櫃公司營收成長情況與營收創新高的公司清單(59家),請到這裡下載:https://miller.pse.is
Thumbnail
▲資本額:5.59 ▲股價:201.5 ▲評分標準(滿分4分):3.6分 營收2、營益4、稅後淨利4、EPS4、存貨(無庫存,不計)、自由現金流量4 ▲已知去年營收:21.5億
Thumbnail
▲資本額:5.59 ▲股價:201.5 ▲評分標準(滿分4分):3.6分 營收2、營益4、稅後淨利4、EPS4、存貨(無庫存,不計)、自由現金流量4 ▲已知去年營收:21.5億
Thumbnail
▲資本額:8.62 ▲股價:267.5 ▲評分標準(滿分4分):2.67分 營收1、營益4、稅後淨利1、EPS4、存貨3、自由現金流量3 ▲預估今年營收:98.4億
Thumbnail
▲資本額:8.62 ▲股價:267.5 ▲評分標準(滿分4分):2.67分 營收1、營益4、稅後淨利1、EPS4、存貨3、自由現金流量3 ▲預估今年營收:98.4億
Thumbnail
▲資本額:27.3 ▲股價:107.5 ▲評分標準(滿分4分):2.33分 營收0、營益3、稅後淨利1、EPS4、存貨3、自由現金流量3 ▲預估今年營收:120.35億 ▲預估今年稅後淨利:12.42億 ▲預估今年EPS:4.5 ▲本益比區間:9.7~25.5 預估今年股價範圍:43.7
Thumbnail
▲資本額:27.3 ▲股價:107.5 ▲評分標準(滿分4分):2.33分 營收0、營益3、稅後淨利1、EPS4、存貨3、自由現金流量3 ▲預估今年營收:120.35億 ▲預估今年稅後淨利:12.42億 ▲預估今年EPS:4.5 ▲本益比區間:9.7~25.5 預估今年股價範圍:43.7
追蹤感興趣的內容從 Google News 追蹤更多 vocus 的最新精選內容追蹤 Google News