mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-11-04 19:53:12 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			67 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
<p>我们把无限数量 ∞ 的栈排成一行,按从左到右的次序从 0 开始编号。每个栈的的最大容量 <code>capacity</code> 都相同。</p>
 | 
						||
 | 
						||
<p>实现一个叫「餐盘」的类 <code>DinnerPlates</code>:</p>
 | 
						||
 | 
						||
<ul>
 | 
						||
	<li><code>DinnerPlates(int capacity)</code> - 给出栈的最大容量 <code>capacity</code>。</li>
 | 
						||
	<li><code>void push(int val)</code> - 将给出的正整数 <code>val</code> 推入 <strong>从左往右第一个 </strong>没有满的栈。</li>
 | 
						||
	<li><code>int pop()</code> - 返回 <strong>从右往左第一个 </strong>非空栈顶部的值,并将其从栈中删除;如果所有的栈都是空的,请返回 <code>-1</code>。</li>
 | 
						||
	<li><code>int popAtStack(int index)</code> - 返回编号 <code>index</code> 的栈顶部的值,并将其从栈中删除;如果编号 <code>index</code> 的栈是空的,请返回 <code>-1</code>。</li>
 | 
						||
</ul>
 | 
						||
 | 
						||
<p> </p>
 | 
						||
 | 
						||
<p><strong>示例:</strong></p>
 | 
						||
 | 
						||
<pre><strong>输入: </strong>
 | 
						||
["DinnerPlates","push","push","push","push","push","popAtStack","push","push","popAtStack","popAtStack","pop","pop","pop","pop","pop"]
 | 
						||
[[2],[1],[2],[3],[4],[5],[0],[20],[21],[0],[2],[],[],[],[],[]]
 | 
						||
<strong>输出:</strong>
 | 
						||
[null,null,null,null,null,null,2,null,null,20,21,5,4,3,1,-1]
 | 
						||
 | 
						||
<strong>解释:</strong>
 | 
						||
DinnerPlates D = DinnerPlates(2);  // 初始化,栈最大容量 capacity = 2
 | 
						||
D.push(1);
 | 
						||
D.push(2);
 | 
						||
D.push(3);
 | 
						||
D.push(4);
 | 
						||
D.push(5);         // 栈的现状为:    2  4
 | 
						||
                                    1  3  5
 | 
						||
                                    ﹈ ﹈ ﹈
 | 
						||
D.popAtStack(0);   // 返回 2。栈的现状为:      4
 | 
						||
                                          1  3  5
 | 
						||
                                          ﹈ ﹈ ﹈
 | 
						||
D.push(20);        // 栈的现状为:  20  4
 | 
						||
                                   1  3  5
 | 
						||
                                   ﹈ ﹈ ﹈
 | 
						||
D.push(21);        // 栈的现状为:  20  4 21
 | 
						||
                                   1  3  5
 | 
						||
                                   ﹈ ﹈ ﹈
 | 
						||
D.popAtStack(0);   // 返回 20。栈的现状为:       4 21
 | 
						||
                                            1  3  5
 | 
						||
                                            ﹈ ﹈ ﹈
 | 
						||
D.popAtStack(2);   // 返回 21。栈的现状为:       4
 | 
						||
                                            1  3  5
 | 
						||
                                            ﹈ ﹈ ﹈ 
 | 
						||
D.pop()            // 返回 5。栈的现状为:        4
 | 
						||
                                            1  3 
 | 
						||
                                            ﹈ ﹈  
 | 
						||
D.pop()            // 返回 4。栈的现状为:    1  3 
 | 
						||
                                           ﹈ ﹈   
 | 
						||
D.pop()            // 返回 3。栈的现状为:    1 
 | 
						||
                                           ﹈   
 | 
						||
D.pop()            // 返回 1。现在没有栈。
 | 
						||
D.pop()            // 返回 -1。仍然没有栈。
 | 
						||
</pre>
 | 
						||
 | 
						||
<p> </p>
 | 
						||
 | 
						||
<p><strong>提示:</strong></p>
 | 
						||
 | 
						||
<ul>
 | 
						||
	<li><code>1 <= capacity <= 20000</code></li>
 | 
						||
	<li><code>1 <= val <= 20000</code></li>
 | 
						||
	<li><code>0 <= index <= 100000</code></li>
 | 
						||
	<li>最多会对 <code>push</code>,<code>pop</code>,和 <code>popAtStack</code> 进行 <code>200000</code> 次调用。</li>
 | 
						||
</ul>
 |