Ouyang_Lianjun 2016-12-31 14:42 采纳率: 0%
浏览 997
已结题

c++运算符重载和模板,求大神指教

 #include<iostream>
using namespace std;

/*
API:
(1)push
(2)pop
(3)isEmpty
(4)Length
*/

////////////////////////////////////////////////////////////////////////
/*
顺序结构实现栈
*/

/*
顺序实现的栈的结构
*/

#define MAXSIZE 1000
template <class T>
class Stack_array{
private:
    T data[MAXSIZE];
    int top;
public:
    Stack_array(){
        top = -1;
    }
    //是否为空
    bool isEmpty(){
        if (top == -1)
            return true;
        return false;
    }
    //插入一个数据
    bool push(T item){
        if (top > MAXSIZE - 1)
        {
            cout << "Overflow the size of the stack" << endl;
            return false;
        }
        ++top;
        data[top] = item;
        return true;
    }
    //删除一个元素
    bool pop(T & item){

        if (top == -1){
            cout << "The stack is Empty" << endl;
            return false;
        }
        item=data[top];
        --top;
        return true;
    }
    //得打栈的长度
    int Length(){
        return top + 1;
    }
    void print(){
        for (int i = 0; i <= top; i++)
        {
            cout << data[i] << " ";
        }
        cout << endl;
    }
    friend ostream &operator <<(ostream &, const Stack_array<T>);
};

template <class T>
ostream & operator <<(ostream & out, const Stack_array<T> & a){
    for (int i = 0; i <= a.top; i++)
    {
        out << a.data[i] << " ";
    }
    out << endl;
    return out;
}


void main(){
    Stack_array<int> s;
    s.push(1);
    s.push(2);
    int item = 0;
    s.pop(item);
    cout << item << endl;
    cout << s << endl;
    s.print();
    system("pause");
}

图片说明

  • 写回答

4条回答

  • threenewbee 2016-12-31 15:00
    关注
    评论

报告相同问题?

悬赏问题

  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料