新股上市增資 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
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
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
清單連結如下,請自行下載: https://docs.google.com/spreadsheets/d/1h-kPNARp7YnI5y_x2PGftCzrl6AgcLiQv0Q512Hqm9s/edit?usp=sharing
Thumbnail
從4月1日上市開始就一路破發,到5月6日的收盤價仍低於發行價,但近兩周的價格有上漲的趨勢,後續應該沒撿便宜的機會了,就先用到目前為止的數據,做個簡單的分析和比較。
Thumbnail
當資產越多,錢的基本單位面額也會提升。然而要擁有更多錢也會變得容易。
2月上市上櫃公司營收成長情況與營收創新高的公司清單  
Thumbnail
2024年01月上市上櫃公司營收數據統計暨創歷史新高公司清單 1月上市上櫃公司營收成長情況與營收創新高的公司清單(59家),請到這裡下載:https://miller.pse.is
Thumbnail
IPO是指一傢俬人公司首次將其股份公開銷售給投資大眾,本文介紹了IPO的原因、投資方式和風險,並列舉了幾個IPO的案例。在投資IPO前,讀者需要仔細研究公司情況,充分了解風險。
Thumbnail
一般來說,新創團隊的出場方式不外乎就是透過上市(Initial Public Offering) 、併購(Mergers and Acquisition)或出售老股,來讓手中的股權變現。 大部分的新創公司在IPO之前,都需要充足的資金來維持運作,所以會進行募資。這筆資金不僅確保公司能夠運作,還能協
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
清單連結如下,請自行下載: https://docs.google.com/spreadsheets/d/1h-kPNARp7YnI5y_x2PGftCzrl6AgcLiQv0Q512Hqm9s/edit?usp=sharing
Thumbnail
從4月1日上市開始就一路破發,到5月6日的收盤價仍低於發行價,但近兩周的價格有上漲的趨勢,後續應該沒撿便宜的機會了,就先用到目前為止的數據,做個簡單的分析和比較。
Thumbnail
當資產越多,錢的基本單位面額也會提升。然而要擁有更多錢也會變得容易。
2月上市上櫃公司營收成長情況與營收創新高的公司清單  
Thumbnail
2024年01月上市上櫃公司營收數據統計暨創歷史新高公司清單 1月上市上櫃公司營收成長情況與營收創新高的公司清單(59家),請到這裡下載:https://miller.pse.is
Thumbnail
IPO是指一傢俬人公司首次將其股份公開銷售給投資大眾,本文介紹了IPO的原因、投資方式和風險,並列舉了幾個IPO的案例。在投資IPO前,讀者需要仔細研究公司情況,充分了解風險。
Thumbnail
一般來說,新創團隊的出場方式不外乎就是透過上市(Initial Public Offering) 、併購(Mergers and Acquisition)或出售老股,來讓手中的股權變現。 大部分的新創公司在IPO之前,都需要充足的資金來維持運作,所以會進行募資。這筆資金不僅確保公司能夠運作,還能協