-
Notifications
You must be signed in to change notification settings - Fork 60
Expand file tree
/
Copy path1845-seat-reservation-manager.js
More file actions
44 lines (41 loc) · 1.17 KB
/
1845-seat-reservation-manager.js
File metadata and controls
44 lines (41 loc) · 1.17 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
/**
* 1845. Seat Reservation Manager
* https://leetcode.com/problems/seat-reservation-manager/
* Difficulty: Medium
*
* Design a system that manages the reservation state of n seats that are numbered from 1 to n.
*
* Implement the SeatManager class:
* - SeatManager(int n) Initializes a SeatManager object that will manage n seats numbered from
* 1 to n. All seats are initially available.
* - int reserve() Fetches the smallest-numbered unreserved seat, reserves it, and returns its
* number.
* - void unreserve(int seatNumber) Unreserves the seat with the given seatNumber.
*/
/**
* @param {number} n
*/
var SeatManager = function(n) {
this.nextAvailable = 1;
this.unreservedSeats = new Set();
};
/**
* @return {number}
*/
SeatManager.prototype.reserve = function() {
if (this.unreservedSeats.size > 0) {
const minSeat = Math.min(...this.unreservedSeats);
if (minSeat < this.nextAvailable) {
this.unreservedSeats.delete(minSeat);
return minSeat;
}
}
return this.nextAvailable++;
};
/**
* @param {number} seatNumber
* @return {void}
*/
SeatManager.prototype.unreserve = function(seatNumber) {
this.unreservedSeats.add(seatNumber);
};