新股上市增資 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
小松鼠的演算法樂園
96會員
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
透過蝦皮分潤計畫,輕鬆賺取零用金!本文分享5-6月實測心得,包含數據流程、實際收入、平臺優點及注意事項,並推薦高分潤商品,教你如何運用空閒時間創造被動收入。
Thumbnail
透過蝦皮分潤計畫,輕鬆賺取零用金!本文分享5-6月實測心得,包含數據流程、實際收入、平臺優點及注意事項,並推薦高分潤商品,教你如何運用空閒時間創造被動收入。
Thumbnail
單身的人有些會養寵物,而我養植物。畢竟寵物離世會傷心,植物沒養好再接再厲就好了~(笑)
Thumbnail
單身的人有些會養寵物,而我養植物。畢竟寵物離世會傷心,植物沒養好再接再厲就好了~(笑)
Thumbnail
不知你有沒有過這種經驗?衛生紙只剩最後一包、洗衣精倒不出來,或電池突然沒電。這次一次補貨,從電池、衛生紙到洗衣精,還順便分享使用心得。更棒的是,搭配蝦皮分潤計畫,愛用品不僅自己用得安心,分享給朋友還能賺回饋。立即使用推薦碼 X5Q344E,輕鬆上手,隨時隨地賺取分潤!
Thumbnail
不知你有沒有過這種經驗?衛生紙只剩最後一包、洗衣精倒不出來,或電池突然沒電。這次一次補貨,從電池、衛生紙到洗衣精,還順便分享使用心得。更棒的是,搭配蝦皮分潤計畫,愛用品不僅自己用得安心,分享給朋友還能賺回饋。立即使用推薦碼 X5Q344E,輕鬆上手,隨時隨地賺取分潤!
Thumbnail
身為一個典型的社畜,上班時間被會議、進度、KPI 塞得滿滿,下班後只想要找一個能夠安靜喘口氣的小角落。對我來說,畫畫就是那個屬於自己的小樹洞。無論是胡亂塗鴉,還是慢慢描繪喜歡的插畫人物,那個專注在筆觸和色彩的過程,就像在幫心靈按摩一樣,讓緊繃的神經慢慢鬆開。
Thumbnail
身為一個典型的社畜,上班時間被會議、進度、KPI 塞得滿滿,下班後只想要找一個能夠安靜喘口氣的小角落。對我來說,畫畫就是那個屬於自己的小樹洞。無論是胡亂塗鴉,還是慢慢描繪喜歡的插畫人物,那個專注在筆觸和色彩的過程,就像在幫心靈按摩一樣,讓緊繃的神經慢慢鬆開。
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億
追蹤感興趣的內容從 Google News 追蹤更多 vocus 的最新精選內容追蹤 Google News