Implement the following operations of a stack using queues.ide
Notes:spa
push to back
, peek/pop from front
, size
, and is empty
operations are valid.Update (2015-06-11):
The class name of the Java function had been updated to MyStack instead of Stack.code
Analyse: Using two queues to store the information. q is used to mock the stack while help is used to store temporary values.orm
1. Time Exceeded Limit Versionblog
It's because transfering temporary queue to the original queue costs a lot of time. element
1 class Stack { 2 private: 3 queue<int> q; 4 queue<int> help; 5 public: 6 // Push element x onto stack. 7 void push(int x) { 8 q.push(x); 9 } 10 11 // Removes the element on top of the stack. 12 void pop() { 13 while(q.size() > 1){ 14 help.push(q.front()); 15 q.pop(); 16 } 17 q.pop(); 18 while(!help.empty()){ 19 q.push(help.front()); 20 } 21 } 22 23 // Get the top element. 24 int top() { 25 while(q.size() > 1){ 26 help.push(q.front()); 27 q.pop(); 28 } 29 int result = q.front(); 30 while(!help.empty()){ 31 q.push(help.front()); 32 } 33 } 34 35 // Return whether the stack is empty. 36 bool empty() { 37 return q.empty(); 38 } 39 };
2. Set a 2-size array to respectively represent the two queue. When it comes to copy the temporary queue to the original queue, just switch the index.it
Runtime: 0ms.io
1 class Stack { 2 private: 3 queue<int> q[2]; 4 int index = 0; 5 public: 6 // Push element x onto stack. 7 void push(int x) { 8 q[index].push(x); 9 } 10 11 // Removes the element on top of the stack. 12 void pop() { 13 while(q[index].size() > 1){ //transfer all other elements into the helper queue 14 q[1 - index].push(q[index].front()); 15 q[index].pop(); 16 } 17 q[index].pop(); 18 index = 1 - index; 19 } 20 21 // Get the top element. 22 int top() { 23 while(q[index].size() > 1){ //transfer all other elements into the helper queue 24 q[1 - index].push(q[index].front()); 25 q[index].pop(); 26 } 27 int result = q[index].front(); 28 q[1- index].push(result); 29 q[index].pop(); 30 index = 1 - index; 31 return result; 32 } 33 34 // Return whether the stack is empty. 35 bool empty() { 36 return q[index].empty(); 37 } 38 };