C++顺序栈的模板实现

本文详细介绍了一种使用C++模板来实现顺序栈的方法。通过定义一个通用的SeqStack类,该类可以处理任何数据类型,从而实现了栈的基本操作如Push、Pop和GetTop等。此外,还包含了判断栈是否为空的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C++顺序栈的模板实现

#pragma once
//顺序栈的实现
#include <iostream>

using namespace std;

const int StackSize = 10;
template<typename DataType>
class SeqStack
{
public:	
	SeqStack(){ top = -1; }
	~SeqStack(){}
	void Push(DataType x);
	DataType Pop();
	DataType GetTop()
	{
		if (top != -1)
		{
			return data[top];
		}
	}
	int Empty(){ top == -1 ? return 1 : return 0; }
private:  
	DataType data[StackSize];
	int top;
};

template<typename DataType>
void SeqStack<DataType>::Push (DataType x)
{
	if (top == StackSize - 1)
	{
		throw"上溢";
	}
	data[++top] = x;
}

template<typename DataType>
DataType SeqStack<DataType>::Pop ()
{
	if (top == -1)
	{
		throw"下溢";
	}
	x = data[top--];
	return x;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值