Skip to content

Latest commit

 

History

History

1172

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 

You have an infinite number of stacks arranged in a row and numbered (left to right) from 0, each of the stacks has the same maximum capacity.

Implement the DinnerPlates class:

  • DinnerPlates(int capacity) Initializes the object with the maximum capacity of the stacks capacity.
  • void push(int val) Pushes the given integer val into the leftmost stack with a size less than capacity.
  • int pop() Returns the value at the top of the rightmost non-empty stack and removes it from that stack, and returns -1 if all the stacks are empty.
  • int popAtStack(int index) Returns the value at the top of the stack with the given index index and removes it from that stack or returns -1 if the stack with that given index is empty.

 

Example 1:

Input
["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], [], [], [], [], []]
Output
[null, null, null, null, null, null, 2, null, null, 20, 21, 5, 4, 3, 1, -1]

Explanation: 
DinnerPlates D = DinnerPlates(2);  // Initialize with capacity = 2
D.push(1);
D.push(2);
D.push(3);
D.push(4);
D.push(5);         // The stacks are now:  2  4
                                           1  3  5
                                           ﹈ ﹈ ﹈
D.popAtStack(0);   // Returns 2.  The stacks are now:     4
                                                       1  3  5
                                                       ﹈ ﹈ ﹈
D.push(20);        // The stacks are now: 20  4
                                           1  3  5
                                           ﹈ ﹈ ﹈
D.push(21);        // The stacks are now: 20  4 21
                                           1  3  5
                                           ﹈ ﹈ ﹈
D.popAtStack(0);   // Returns 20.  The stacks are now:     4 21
                                                        1  3  5
                                                        ﹈ ﹈ ﹈
D.popAtStack(2);   // Returns 21.  The stacks are now:     4
                                                        1  3  5
                                                        ﹈ ﹈ ﹈ 
D.pop()            // Returns 5.  The stacks are now:      4
                                                        1  3 
                                                        ﹈ ﹈  
D.pop()            // Returns 4.  The stacks are now:   1  3 
                                                        ﹈ ﹈   
D.pop()            // Returns 3.  The stacks are now:   1 
                                                        ﹈   
D.pop()            // Returns 1.  There are no stacks.
D.pop()            // Returns -1.  There are still no stacks.

 

Constraints:

  • 1 <= capacity <= 2 * 104
  • 1 <= val <= 2 * 104
  • 0 <= index <= 105
  • At most 2 * 105 calls will be made to push, pop, and popAtStack.

Companies:
ByteDance, Amazon

Related Topics:
Hash Table, Stack, Design, Heap (Priority Queue)

Solution 1.

// OJ: https://leetcode.com/problems/dinner-plate-stacks/
// Author: github.com/lzl124631x
// Time:
//      DinnerPlates: O(1)
//      push: O(logN)
//      pop: O(logN)
//      popAtStack: (logN)
// Space: O(N)
class DinnerPlates {
    int capacity;
    vector<stack<int>> v;
    set<int> avail; // the last stack is not in avail
public:
    DinnerPlates(int capacity) : capacity(capacity) {}
    void push(int val) {
        if (avail.size()) {
            int i = *avail.begin();
            v[i].push(val);
            if (v[i].size() == capacity) avail.erase(i);
        } else {
            if (v.empty() || v.back().size() == capacity) v.emplace_back();
            v.back().push(val);
        }
    }
    int pop() {
        while (v.size() && v.back().empty()) v.pop_back();
        if (v.empty()) return -1;
        int val = v.back().top();
        v.back().pop();
        if (v.back().empty()) {
            v.pop_back();
            if (avail.count(v.size() - 1)) avail.erase(v.size() - 1);
        }
        return val;
    }
    int popAtStack(int index) {
        if (index >= v.size() || v[index].empty()) return -1;
        if (index == v.size() - 1) return pop();
        int val = v[index].top();
        v[index].pop();
        avail.insert(index);
        return val;
    }
};