日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

LeetCode 826. 安排工作以达到最大收益(map)

發(fā)布時(shí)間:2024/7/5 编程问答 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 LeetCode 826. 安排工作以达到最大收益(map) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1. 題目

有一些工作:difficulty[i] 表示第i個(gè)工作的難度,profit[i]表示第i個(gè)工作的收益。

現(xiàn)在我們有一些工人。worker[i]是第i個(gè)工人的能力,即該工人只能完成難度小于等于worker[i]的工作。

每一個(gè)工人都最多只能安排一個(gè)工作,但是一個(gè)工作可以完成多次。

舉個(gè)例子,如果3個(gè)工人都嘗試完成一份報(bào)酬為1的同樣工作,那么總收益為 $3。如果一個(gè)工人不能完成任何工作,他的收益為 $0 。

我們能得到的最大收益是多少?

示例: 輸入: difficulty = [2,4,6,8,10], profit = [10,20,30,40,50], worker = [4,5,6,7] 輸出: 100 解釋: 工人被分配的工作難度是 [4,4,6,6] ,分別獲得 [20,20,30,30] 的收益。提示: 1 <= difficulty.length = profit.length <= 10000 1 <= worker.length <= 10000 difficulty[i], profit[i], worker[i] 的范圍是 [1, 10^5]

來(lái)源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/most-profit-assigning-work
著作權(quán)歸領(lǐng)扣網(wǎng)絡(luò)所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系官方授權(quán),非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。

2. 解題

  • 先遍歷所有的難度的工作,找到該難度工作的最大收益,存入map
  • 遍歷一次map,記錄過(guò)程中的最大利益,更新后面難度更高的情況下,能獲得的最大收益
class Solution { public:int maxProfitAssignment(vector<int>& difficulty, vector<int>& profit, vector<int>& worker) {map<int,int> m;//難度,該難度及以下,收益最高的工作for(int i = 0; i < difficulty.size(); ++i)m[difficulty[i]] = max(m[difficulty[i]], profit[i]);//同一難度,最大的收益int maxprofit = -1, ans = 0;for(auto it = m.begin(); it != m.end(); ++it){maxprofit = max(maxprofit, it->second);//比如難度是8,收益2,難度3,收益5,可以干難度8的人,可以選擇收益為5的活//這樣收益最大化it->second = maxprofit;}for(int i = 0; i < worker.size(); ++i){ //二分查找難度的上界,讀取其收益auto it = m.upper_bound(worker[i]);if(it != m.begin())ans += (--it)->second;}return ans;} };

276 ms 40 MB

總結(jié)

以上是生活随笔為你收集整理的LeetCode 826. 安排工作以达到最大收益(map)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。