面向对象编程技术(作业题三)

#include <iostream>

using namespace std;

template<typename T>
class CStack
{
protected:
 T* m_pData;
 int m_nLength;  // 栈长度
 int m_nCount;  // 当前元素个数

public:
 CStack(int nSize);
 ~CStack();
 void Push(const T& val); // 入栈操作
 void Pop();     // 出栈操作
 const T& Top() const;  // 获取栈顶元素
};

template<typename T>
CStack<T>::CStack(int nSize)
{
 m_pData = new T[nSize];
 if(!m_pData)
    {
        cout<<"分配内存失败。"<<endl;
        exit(1);
    }

 m_nLength = nSize;
 m_nCount = 0;
}

template<typename T>
CStack<T>::~CStack()
{
 if (m_pData)
 {
  delete[] m_pData;
  m_pData = NULL;
 }
}

template<typename T>
void CStack<T>::Push(const T& val)
{
 if (m_nCount == m_nLength)
 {
  cout<<"堆栈已满。"<<endl;
  return;
 }
 m_pData[m_nCount] = val;
 m_nCount++;
}

template<typename T>
void CStack<T>::Pop()
{
 if (m_nCount == 0)
 {
  cout<<"堆栈已空。"<<endl;
  return;
 }
 m_nCount--;
}

template<typename T>
const T&  CStack<T>::Top() const
{
 if (m_nCount == 0)
 {
  cout<<"堆栈已空。"<<endl;
  return 0;
 }

 return m_pData[m_nCount-1];
}


///
int main(int argc, char* argv[])
{
 CStack<char> stkChar(3);
 CStack<double> stkDouble(3);
 char chCurrent;
 double dCurrent;

 // 初始化
 stkChar.Push('a');
 stkChar.Push('b');
 stkDouble.Push(1.2);
 stkDouble.Push(2.4);

 // 字符堆栈
 chCurrent = stkChar.Top();
 cout<<chCurrent<<endl;
 stkChar.Pop();
 chCurrent = stkChar.Top();
 cout<<chCurrent<<endl;
 stkChar.Pop();
 stkChar.Top();  // 堆栈已空

 // 浮点数堆栈
 dCurrent = stkDouble.Top();
 cout<<dCurrent<<endl;
 stkDouble.Pop();
 dCurrent = stkDouble.Top();
 cout<<dCurrent<<endl;
 stkDouble.Pop();
 stkDouble.Pop();  // 堆栈已空

 return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值