<p>请你设计一个管理 <code>n</code> 个座位预约的系统,座位编号从 <code>1</code> 到 <code>n</code> 。</p> <p>请你实现 <code>SeatManager</code> 类:</p> <ul> <li><code>SeatManager(int n)</code> 初始化一个 <code>SeatManager</code> 对象,它管理从 <code>1</code> 到 <code>n</code> 编号的 <code>n</code> 个座位。所有座位初始都是可预约的。</li> <li><code>int reserve()</code> 返回可以预约座位的 <strong>最小编号</strong> ,此座位变为不可预约。</li> <li><code>void unreserve(int seatNumber)</code> 将给定编号 <code>seatNumber</code> 对应的座位变成可以预约。</li> </ul> <p> </p> <p><strong>示例 1:</strong></p> <pre><strong>输入:</strong> ["SeatManager", "reserve", "reserve", "unreserve", "reserve", "reserve", "reserve", "reserve", "unreserve"] [[5], [], [], [2], [], [], [], [], [5]] <strong>输出:</strong> [null, 1, 2, null, 2, 3, 4, 5, null] <strong>解释:</strong> SeatManager seatManager = new SeatManager(5); // 初始化 SeatManager ,有 5 个座位。 seatManager.reserve(); // 所有座位都可以预约,所以返回最小编号的座位,也就是 1 。 seatManager.reserve(); // 可以预约的座位为 [2,3,4,5] ,返回最小编号的座位,也就是 2 。 seatManager.unreserve(2); // 将座位 2 变为可以预约,现在可预约的座位为 [2,3,4,5] 。 seatManager.reserve(); // 可以预约的座位为 [2,3,4,5] ,返回最小编号的座位,也就是 2 。 seatManager.reserve(); // 可以预约的座位为 [3,4,5] ,返回最小编号的座位,也就是 3 。 seatManager.reserve(); // 可以预约的座位为 [4,5] ,返回最小编号的座位,也就是 4 。 seatManager.reserve(); // 唯一可以预约的是座位 5 ,所以返回 5 。 seatManager.unreserve(5); // 将座位 5 变为可以预约,现在可预约的座位为 [5] 。 </pre> <p> </p> <p><strong>提示:</strong></p> <ul> <li><code>1 <= n <= 10<sup>5</sup></code></li> <li><code>1 <= seatNumber <= n</code></li> <li>每一次对 <code>reserve</code> 的调用,题目保证至少存在一个可以预约的座位。</li> <li>每一次对 <code>unreserve</code> 的调用,题目保证 <code>seatNumber</code> 在调用函数前都是被预约状态。</li> <li>对 <code>reserve</code> 和 <code>unreserve</code> 的调用 <strong>总共</strong> 不超过 <code>10<sup>5</sup></code> 次。</li> </ul>