IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 栈的实现(顺序表实现) -> 正文阅读

[C++知识库]栈的实现(顺序表实现)

?

?

顺序栈实现太简单了,直接看代码吧

导向链接:栈的建立【包括入栈出栈显示】(基于单链表实现)_inbSorryMaker的博客-CSDN博客

//基本栈的结构
template <class E>        //模板
class Stack {			//栈的类定义
public:
     Stack(){ };			//构造函数
     virtual void Push(E x) = 0;             //进栈
     virtual bool Pop(E& x) = 0;	     //出栈
     virtual bool getTop(E& x) = 0;	     //取栈顶
     virtual bool IsEmpty() = 0;	     //判栈空
     virtual bool IsFull() = 0;		     //判栈满
};

?顺序栈头文件

#include <assert.h>
#include <iostream.h>
#include “stack.h”
template <class E>
class SeqStack : public Stack<E> {   //顺序栈类定义
private: 
     E *elements;			//栈元素存放数组
     int top;				//栈顶指针
     int maxSize;               		//栈最大容量
     void overflowProcess();	//栈的溢出处理
public:
     SeqStack(int sz =50);		//构造函数
     ~SeqStack() { delete []elements; }   //析构函数
     void Push(E x);	          		//进栈
     bool Pop(E& x);		//出栈
     bool getTop(E& x);		//取栈顶内容
     bool IsEmpty() const { return top == -1; }
     bool IsFull() const { return top == maxSize-1; }
};

具体实现

template <class E>
void SeqStack<E>::overflowProcess() {
//私有函数:当栈满则执行扩充栈存储空间处理
     E *newArray = new E[2*maxSize];				//创建更大的存储数组
	 for (int i = 0; i <= top; i++) 
          newArray[i] = elements[i];
	 maxSize += maxSize;  
     delete [ ]elements;  
     elements = newArray;  	//改变elements指针
}; 

template <class E>
void SeqStack<E>::Push(E x) {   
//若栈不满, 则将元素x插入该栈栈顶, 否则溢出处理
	  if (IsFull() == true) overflowProcess;	      //栈满
	  elements[++top] = x;	     //栈顶指针先加1, 再进栈
}; 

template <class E>
bool SeqStack<E>::Pop(E& x) {
//函数退出栈顶元素并返回栈顶元素的值
	  if (IsEmpty() == true) return false;
	  x = elements[top--];	     //栈顶指针退1
      return true;		     //退栈成功
};	 

template <class E>
bool Seqstack<E>::getTop(E& x) {
//若栈不空则函数返回该栈栈顶元素的地址
	 if (IsEmpty() == true) return false;
	 x = elements[top];
     return true;
};

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-10-03 16:54:12  更:2021-10-03 16:55:11 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 1:27:13-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码