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
    关注
    评论

报告相同问题?

悬赏问题

  • ¥15 用verilog实现tanh函数和softplus函数
  • ¥15 求京东批量付款能替代天诚
  • ¥15 slaris 系统断电后,重新开机后一直自动重启
  • ¥15 51寻迹小车定点寻迹
  • ¥15 谁能帮我看看这拒稿理由啥意思啊阿啊
  • ¥15 关于vue2中methods使用call修改this指向的问题
  • ¥15 idea自动补全键位冲突
  • ¥15 请教一下写代码,代码好难
  • ¥15 iis10中如何阻止别人网站重定向到我的网站
  • ¥15 滑块验证码移动速度不一致问题