dragonir 2015-10-26 11:43 采纳率: 100%
浏览 2243
已采纳

C++链栈的实现实在不会写,求大神帮忙。

Description
请实现以下栈类的定义:

enum ErrorCode

{

     success,

     underflow,

     overflow

};

template

struct Node

{

     StackEntry data;

     Node *next;

};

template

class MyStack

{

public:

     MyStack();

     /*

               判断栈是否为空,若为空则返回true,非空则返回false

      */

     bool empty() const;

     int size() const;

     /*

               出栈操作,若正常出栈则返回success,若栈内无元素则返回underflow

      */

     ErrorCode pop();

     /*

               获取栈顶元素,若正常获取到栈顶元素则返回success,若栈内无元素则返回underflow

               元素内容保存在引用参数item中

      */

     ErrorCode top(StackEntry &item) const;

     /*

               入栈操作,若正常入栈则返回success,若入栈失败则返回overflow

      */

     ErrorCode push(const StackEntry &item);

     /*

               清空栈

      */

     void clear();

private:

     Node<StackEntry> *pTop;

};

注意,只需要提交类的声明以及函数实现,不需要提交main函数。

Hint
注意,只需要提交类的声明以及函数实现,不需要提交main函数。

  • 写回答

4条回答 默认 最新

  • Huppert 2015-10-27 12:05
    关注
     enum ErrorCode
    {
         success,
    
         underflow,
    
         overflow
    };
    template < typename StackEntry>
    struct Node
    {
         StackEntry data;
    
         Node *next;
    };
    
    template < typename StackEntry>
    class MyStack
    {
    public:
         MyStack() : pTop(NULL){}
    
         /*
    
                   判断栈是否为空,若为空则返回true,非空则返回false
    
          */
    
         bool empty() const {return pTop == NULL;}
    
         int size() const
         {
             int size = 0;
             Node<StackEntry> * p = pTop;
             while(p)
             {
                 ++size;
                 p = p->next;
             }
             return size;
         }
    
         /*
    
                   出栈操作,若正常出栈则返回success,若栈内无元素则返回underflow
    
          */
    
         ErrorCode pop()
         {
             if(empty())
             {
                 return underflow;
             }
             Node<StackEntry> * p = pTop;
             pTop = pTop->next;
             delete p;
             return success;
         }
    
         /*
    
                   获取栈顶元素,若正常获取到栈顶元素则返回success,若栈内无元素则返回underflow
    
                   元素内容保存在引用参数item中
    
          */
    
         ErrorCode top(StackEntry &item) const
         {
             if(empty())
             {
                 return underflow;
             }
             item = pTop->data;
             return success;
         }
    
         /*
    
                   入栈操作,若正常入栈则返回success,若入栈失败则返回overflow
    
          */
    
         ErrorCode push(const StackEntry &item)
         {
             Node<StackEntry> * p = new Node<StackEntry>();
             if(!p)
             {
                 return overflow;
             }
             p->data = item;
             p->next = pTop;
             pTop = p;
             return success;
         }
    
         /*
    
                   清空栈
    
          */
    
         void clear()
         {
             Node<StackEntry> * p = pTop;
             while(p)
             {
                 Node<StackEntry> * q = p;
                 p = p->next;
                 delete q;
             }
             pTop = NULL;
         }
    private:
         Node<StackEntry> *pTop;
    };
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥20 求数据集和代码#有偿答复
  • ¥15 关于下拉菜单选项关联的问题
  • ¥20 java-OJ-健康体检
  • ¥15 rs485的上拉下拉,不会对a-b<-200mv有影响吗,就是接受时,对判断逻辑0有影响吗
  • ¥15 使用phpstudy在云服务器上搭建个人网站
  • ¥15 应该如何判断含间隙的曲柄摇杆机构,轴与轴承是否发生了碰撞?
  • ¥15 vue3+express部署到nginx
  • ¥20 搭建pt1000三线制高精度测温电路
  • ¥15 使用Jdk8自带的算法,和Jdk11自带的加密结果会一样吗,不一样的话有什么解决方案,Jdk不能升级的情况
  • ¥15 画两个图 python或R