javascript的数组实现数据结构中的堆栈和队列
简单的利用javascript的数组实现数据结构中的堆栈和队列。Stack.js源码:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 | /* * @brief: 定义堆栈类 * @remark: 实现堆栈基本功能 */functionStack(){    //存储元素数组    varaElement = newArray();    /*    * @brief: 元素入栈    * @param: 入栈元素列表    * @return: 堆栈元素个数    * @remark: 1.Push方法参数可以多个    *    2.参数为空时返回-1    */    Stack.prototype.Push = function(vElement){        if(arguments.length == 0)            return- 1;        //元素入栈        for(vari = 0; i < arguments.length; i++){            aElement.push(arguments[i]);        }        returnaElement.length;    }    /*    * @brief: 元素出栈    * @return: vElement    * @remark: 当堆栈元素为空时,返回null    */    Stack.prototype.Pop = function(){        if(aElement.length == 0)            returnnull;        else            returnaElement.pop();    }    /*    * @brief: 获取堆栈元素个数    * @return: 元素个数    */    Stack.prototype.GetSize = function(){        returnaElement.length;    }    /*    * @brief: 返回栈顶元素值    * @return: vElement    * @remark: 若堆栈为空则返回null    */    Stack.prototype.GetTop = function(){        if(aElement.length == 0)            returnnull;        else            returnaElement[aElement.length - 1];    }    /*    * @brief: 将堆栈置空      */    Stack.prototype.MakeEmpty = function(){        aElement.length = 0;    }    /*    * @brief: 判断堆栈是否为空    * @return: 堆栈为空返回true,否则返回false    */    Stack.prototype.IsEmpty = function(){        if(aElement.length == 0)            returntrue;        else            returnfalse;    }    /*    * @brief: 将堆栈元素转化为字符串    * @return: 堆栈元素字符串    */    Stack.prototype.toString = function(){        varsResult = (aElement.reverse()).toString();        aElement.reverse()        returnsResult;    }} | 
Queue.js源码:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 | /* * @brief: 定义队列类 * @remark:实现队列基本功能 */functionQueue(){    //存储元素数组    varaElement = newArray();    /*    * @brief: 元素入队    * @param: vElement元素列表    * @return: 返回当前队列元素个数    * @remark: 1.EnQueue方法参数可以多个    *    2.参数为空时返回-1    */    Queue.prototype.EnQueue = function(vElement){        if(arguments.length == 0)            return- 1;        //元素入队        for(vari = 0; i < arguments.length; i++){            aElement.push(arguments[i]);        }        returnaElement.length;    }    /*    * @brief: 元素出队    * @return: vElement    * @remark: 当队列元素为空时,返回null    */    Queue.prototype.DeQueue = function(){        if(aElement.length == 0)            returnnull;        else            returnaElement.shift();    }    /*    * @brief: 获取队列元素个数    * @return: 元素个数    */    Queue.prototype.GetSize = function(){        returnaElement.length;    }    /*    * @brief: 返回队头素值    * @return: vElement    * @remark: 若队列为空则返回null    */    Queue.prototype.GetHead = function(){        if(aElement.length == 0)            returnnull;        else            returnaElement[0];    }    /*    * @brief: 返回队尾素值    * @return: vElement    * @remark: 若队列为空则返回null    */    Queue.prototype.GetEnd = function(){        if(aElement.length == 0)            returnnull;        else            returnaElement[aElement.length - 1];    }    /*    * @brief: 将队列置空      */    Queue.prototype.MakeEmpty = function(){        aElement.length = 0;    }    /*    * @brief: 判断队列是否为空    * @return: 队列为空返回true,否则返回false    */    Queue.prototype.IsEmpty = function(){        if(aElement.length == 0)            returntrue;        else            returnfalse;    }    /*    * @brief: 将队列元素转化为字符串    * @return: 队列元素字符串    */    Queue.prototype.toString = function(){        varsResult = (aElement.reverse()).toString();        aElement.reverse()        returnsResult;    }} | 
测试:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 | varoStack = newStack();oStack.Push("abc", "123", 890);console.log(oStack.toString());oStack.Push("qq");console.log(oStack.toString());//  alert(oStack.GetSize());//  alert(oStack.Pop());//  alert(oStack.GetTop());//  oStack.MakeEmpty();//  alert(oStack.GetSize());//  alert(oStack.toString());deleteoStack;varoQueue = newQueue();oQueue.EnQueue("bbs", "fans", "bruce");console.log(oQueue.toString());oQueue.EnQueue(23423);console.log(oQueue.toString());//  alert(oQueue.DeQueue());//  alert(oQueue.GetSize());//  alert(oQueue.GetHead());//  alert(oQueue.GetEnd());//  oQueue.MakeEmpty();//  alert(oQueue.IsEmpty());//  alert(oQueue.toString());deleteoQueue; | 
 
                     
                    
                 
                    
                 
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号