1235. Maximum Profit in Job Scheduling

https://leetcode.com/problems/maximum-profit-in-job-scheduling/

We have n jobs, where every job is scheduled to be done from startTime[i] to endTime[i], obtaining a profit of profit[i].

You're given the startTime , endTime and profit arrays, you need to output the maximum profit you can take such that there are no 2 jobs in the subset with overlapping time range.

If you choose a job that ends at time X you will be able to start another job that starts at time X.

Example 1:

Example 2:

Example 3:

Constraints:

  • 1 <= startTime.length == endTime.length == profit.length <= 5 * 10^4

  • 1 <= startTime[i] < endTime[i] <= 10^9

  • 1 <= profit[i] <= 10^4

给定一系列任务,每项任务有<初始时间,终止时间,利润>,同一时间只能执行一项任务,问最大利润能有多少。此题表面是区间问题,但如果陷入区间问题的思路(如扫描线,区间合并等)就掉入了陷阱。本质上是个选子集的问题,每个job有选or不选=>DP。时间可以看作是一种特殊的背包,dp是一个treemap,dp[i]表示截止到时间点i,最大的利润是多少。根据任务的endTime作排序并遍历。针对选当前任务i时,利用tree map快速定位到截止到startTime时最大利润是多少并加上当前任务的profit,与不选i时最大利润比较,如果大则把i插入dp。

Last updated

Was this helpful?