数据结构 - 顺序栈的实现 C++
2024-10-19 22:39:58
顺序栈封装 C++
使用C++对顺序栈进行了简单的封装,实现了栈的基本操作
封装方法: pop(),top(),size(),empty(),push()
代码已经过测试
#pragma once
#include <iostream>
#include <algorithm>
using namespace std;
template<class T> class Stack {
public:
Stack(); //构造函数
void pop(); //弹出头元素
void push(T value); //入栈
bool empty(); //判断是否为空栈
int size(); //返回栈的大小
T top(); //获取首元素
private:
T arr[100];
int head;
int tail;
int len;
};
template<class T>
inline Stack<T>::Stack()
{
this->head = 0;
this->tail = 0;
this->len = 0;
}
template<class T>
inline void Stack<T>::pop()
{
this->head--;
this->len--;
}
template<class T>
inline void Stack<T>::push(T value)
{
head++;
arr[head] = value;
this->len++;
}
template<class T>
inline bool Stack<T>::empty()
{
if(this->len == 0)
return true;
else return false;
}
template<class T>
inline int Stack<T>::size()
{
return this->len;
}
template<class T>
inline T Stack<T>::top()
{
return T(arr[head]);
}
如果大家有什么疑问的话可以加qq向我提出哦,欢迎各位大佬指出问题。
如果你觉得对你有所帮助的话就给我点个赞,点燃我下次写文章的动力吧 _ !
最新文章
- 工作上遇到的问题 DEBUG 001
- Android斗地主棋牌游戏牌桌实现源码下载
- BZOJ 4619 Swap Space 解题报告
- 打开office2010里面的access,总是提示要配置Office single image
- Android深入浅出之Binder机制
- xargs -r
- HDU 4937 Lucky Number (数学,进制转换)
- HDU ACM 1050 Moving Tables
- Oracle 基础知识
- Oracle创建主键自增表
- App 推荐:Spotify
- Qt之再谈窗体阴影
- BZOJ 3566: [SHOI2014]概率充电器( 树形dp )
- GPRS的工作原理、主要特点
- Angular2之管道学习笔记
- oracle删除字段中的空格、回车及指定字符
- 到处是坑的微信公众号支付开发(java)
- 编写MyCP.java 实现类似Linux下cp XXX1 XXX2的功能
- arraylist 为什么 删除元素时要使用迭代器而不能使用遍历
- phoneshop cs6破解
热门文章
- logstash设置开机自启动
- 笔记:Map(就是用来Ctrl+C,V的)
- 第十五节:Asp.Net Core中的各种过滤器(授权、资源、操作、结果、异常)
- BFS --- 模板题
- FreeSWITCH 总体架构
- Effective.Java第78-90条(同步相关)
- SpringBoot:4.SpringBoot整合Mybatis实现数据库访问
- npm是干什么的(转)
- 用友U9 部署
- c# DataRow[]转Datatable