Back to Practice Dashboard
Competitive ProgrammingEasy
Job Sequencing
Learn how to solve the 'Job Sequencing' problem. This detailed resource details brute force and optimized approaches.
Problem Statement
Easy
Write a function job_scheduling(jobs) that takes a list of tuples jobs where each tuple is (job_id, deadline, profit). Each job takes 1 unit of time to complete. Find the maximum profit and the number of jobs completed, and return them as a tuple (job_count, max_profit).
Constraints
- •1 <= len(jobs) <= 10^4
- •1 <= deadline <= 100
- •1 <= profit <= 1000
Examples
Example 1
Input
job_scheduling([(1, 4, 20), (2, 1, 10), (3, 1, 40), (4, 1, 30)])
Output
(2, 60)
Explanation
We can do job 3 at time 1 and job 1 at time 2. Total profit is 40 + 20 = 60.
Example 2
Input
job_scheduling([(1, 2, 100), (2, 1, 19), (3, 2, 27), (4, 1, 25), (5, 3, 15)])
Output
(3, 142)
Explanation
We can do job 1, 3, and 5 for a total profit of 100 + 27 + 15 = 142.
Need a Hint?
Analyze the input constraints. Try sorting first (O(n log n)) or using a hash map/set to track seen elements in O(n) time.
Edge Cases to Watch
- Empty list or null input variables
- Single item lists/arrays
- Extremely large input bounds causing integer or stack overflow
Ready to Solve?
Open the problem in PyRun's browser-based Python editor. Your code runs fully offline — no server required.