c++顺序表实现栈

本文详细介绍了一种基于模板的栈类设计与实现方法,利用capacity控制最大容量,避免多次插入时的频繁扩容操作,提高了数据结构的效率。文章深入探讨了栈类的各种操作,包括push、pop、top等,并提供了完整的代码示例。

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

通过capacity控制最大容量,超过就扩容,可以避免多次插入时的扩充操作 

template<class T>
class Stack {
public:
	Stack();
	Stack(const size_t & length);
	Stack(const Stack<T> & s);
	~Stack();
	void push(const T & elem);
	void pop();
	const T & top() const { return empty() ? NULL : m_elem[m_top]; }
	size_t size() const { return m_top + 1; }
	size_t capacity() const { return m_capacity; }
	bool empty() const { return -1 == m_top; }
private:
	T *m_elem; // 栈内元素储存的地方
	size_t m_capacity; // 最大容量
	int m_top; // 栈头指针
};

template<class T>
Stack<T>::Stack()
{
	m_elem = nullptr;
	m_capacity = 0;
	m_top = -1;
}

template<class T>
Stack<T>::Stack(const size_t & length)
{
	m_elem = new T[length];
	m_capacity = length;
	m_top = -1;
	memset(m_elem, NULL, sizeof(m_elem));
}

template<class T>
Stack<T>::Stack(const Stack<T>& s)
{
	m_elem = new T[s.size()];
	m_capacity = s.m_capacity;
	m_top = s.m_top;
	for (size_t i = 0; i < m_capacity; ++i) {
		m_elem[i] = s.m_elem[i];
	}
}

template<class T>
Stack<T>::~Stack()
{
	delete[] m_elem;
	m_elem = nullptr;
	m_capacity = 0;
	m_top = -1;
}

template<class T>
void Stack<T>::push(const T & elem)
{
	m_top++;
	// 头指针到了最大容量的时候就扩容,扩展多少取决于数据数量
	if (m_top == m_capacity) {
		int i;
		m_capacity = m_capacity + 10;
		T * temp = new T[m_capacity]; 
		memset(temp, NULL, sizeof(temp));
		for (i = 0; i < m_top; ++i) {
			temp[i] = m_elem[i];
		}
		temp[m_top] = elem;
		m_elem = temp;
		temp = nullptr;
		delete temp;
	}
	else {
		m_elem[m_top] = elem;
	}
}

template<class T>
void Stack<T>::pop()
{
	if (-1 != m_top) {
		m_top--;
	}
}

int main() {
	Stack<int> s(10);
	int n = 20;
	for (int i = 0; i < n; ++i) {
		s.push(i * 2 - 1);
	}
	for (int i = 0; i < n + 1; ++i) {
		s.pop();
	}
	return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值