javascript coding test course, assigning meeting rooms

October 10, 2023

Problem Description

Efficiently assigning meeting rooms is a critical issue in modern office environments. Given a list of meetings with their start and end times, the problem is to write an algorithm to assign as many meetings as possible to meeting rooms without overlapping.

Input:

  • meetings: A 2D array where each array consists of [startTime, endTime].

Output:

  • The maximum number of meetings that can be assigned.

Example

For example, let’s assume there is a list of meetings as follows.


            [[0, 30], [5, 10], [15, 20]]
        

The maximum number of meetings that can be assigned here is 2. (The meeting [0, 30] does not overlap with [5, 10] and [15, 20]).

Approach to the Problem

This problem can be solved using a greedy algorithm. We will sort the meetings based on their ending times and then assign meetings starting from the one that ends the earliest. This way, we can utilize the resources of the meeting room to the fullest.

  1. First, sort the list of meetings based on their ending times.
  2. Select the first meeting, and if the start time of the next meeting is greater than the ending time of the currently selected meeting, select the new meeting.
  3. Repeat this process until the end of the list of meetings.

JavaScript Implementation

Now, let’s implement the above approach in JavaScript code.


function maximumMeetings(meetings) {
    // Sort by meeting ending times
    meetings.sort((a, b) => a[1] - b[1]);
    
    let count = 0;
    let lastEndTime = 0;

    for (let i = 0; i < meetings.length; i++) {
        // If the start time of the current meeting is greater than or equal to the ending time of the last selected meeting
        if (meetings[i][0] >= lastEndTime) {
            count++;
            lastEndTime = meetings[i][1]; // Update the ending time of the last selected meeting
        }
    }

    return count;
}

// Example for testing
const testMeetings = [[0, 30], [5, 10], [15, 20]];
console.log(maximumMeetings(testMeetings)); // Output: 2
        

Complexity Analysis

The time complexity of this algorithm is O(n log n). This is due to the time taken to sort the meetings. The process of counting the maximum number of meetings from the sorted list is O(n). Therefore, the overall time complexity is O(n log n). The space complexity is O(1), meaning that no additional space is needed even if using a sorted list.

Conclusion

The “Meeting Room Assignment” problem is a representative problem that can be efficiently solved using a greedy algorithm. This problem teaches how to avoid meeting overlaps and make the most of resources. The code implemented in JavaScript above can help in solving this problem. Based on this, it will be possible to lay the groundwork for solving various algorithmic problems.