You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					26 lines
				
				500 B
			
		
		
			
		
	
	
					26 lines
				
				500 B
			|   
											4 months ago
										 | 'use strict'; | ||
|  | var Queue = function () { | ||
|  |   this.head = null; | ||
|  |   this.tail = null; | ||
|  | }; | ||
|  | 
 | ||
|  | Queue.prototype = { | ||
|  |   add: function (item) { | ||
|  |     var entry = { item: item, next: null }; | ||
|  |     var tail = this.tail; | ||
|  |     if (tail) tail.next = entry; | ||
|  |     else this.head = entry; | ||
|  |     this.tail = entry; | ||
|  |   }, | ||
|  |   get: function () { | ||
|  |     var entry = this.head; | ||
|  |     if (entry) { | ||
|  |       var next = this.head = entry.next; | ||
|  |       if (next === null) this.tail = null; | ||
|  |       return entry.item; | ||
|  |     } | ||
|  |   } | ||
|  | }; | ||
|  | 
 | ||
|  | module.exports = Queue; |