标签:
Implement the following operations of a stack using queues.
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.
https://leetcode.com/problems/implement-stack-using-queues/
1 /** 2 * @constructor 3 */ 4 var Stack = function() { 5 this.queueA = []; 6 this.queueB = []; 7 }; 8 9 /** 10 * @param {number} x 11 * @returns {void} 12 */ 13 Stack.prototype.push = function(x) { 14 if(this.queueA.length !== 0){ 15 this.queueA.push(x); 16 }else{ 17 this.queueB.push(x); 18 } 19 }; 20 21 Stack.prototype.moveAToB = function() { 22 if(this.queueB.length !== 0){ 23 var tmp = this.queueA; 24 this.queueA = this.queueB; 25 this.queueB = tmp; 26 } 27 var len = this.queueA.length; 28 for(var i = 0; i < len - 1; i++){ 29 var queuePeek = this.queueA.shift(); 30 this.queueB.push(queuePeek); 31 } 32 }; 33 34 /** 35 * @returns {void} 36 */ 37 Stack.prototype.pop = function() { 38 this.moveAToB(); 39 this.queueA.shift(); 40 }; 41 42 /** 43 * @returns {number} 44 */ 45 Stack.prototype.top = function() { 46 this.moveAToB(); 47 var stackTop = this.queueA.shift(); 48 this.queueB.push(stackTop); 49 return stackTop; 50 }; 51 52 /** 53 * @returns {boolean} 54 */ 55 Stack.prototype.empty = function() { 56 if(this.queueA.length === 0 && this.queueB.length === 0){ 57 return true; 58 } 59 return false; 60 };
[LeetCode][JavaScript]Implement Stack using Queues
标签:
原文地址:http://www.cnblogs.com/Liok3187/p/4572856.html