顺序栈(C++)
栈的定义为只允许在表的末端进行插入和删除的线性表。简而言之就是先进后出的线性表。
插入和删除的一端被称呼为栈顶(top),而不允许插入删除的一端被称为栈底(bottom)。无元素时的栈即为空栈。

使用一维数组实现栈
//stack.h
#ifndef STACK_H
#define STACK_H
#include<iostream>
#include<assert.h>
using namespace std;
const int maxSize = 50; template<class T>
class Stack
{
public:
Stack(){};
virtual void Push(const T& x) = 0;
virtual void Pop(T& x) = 0;
virtual bool getTop(T& x) = 0;
virtual bool IsEmpty()const = 0;
virtual bool IsFull()const = 0;
virtual int getSize()const = 0;
};
#endif
//main.cpp
#include"stack.h"
const int stackIncreament = 20; template<class T>
class SeqStack : public Stack<T>
{
private:
T *elements; //栈数组
int top; //栈顶指针
int maxSize;//栈的大小
void overflowProcess();//自动扩容函数
public:
SeqStack(int sz = 50);
~SeqStack(){delete[]this->elements;}
void Push(const T& x);//向栈中压入元素
void Pop(T& x);//出栈
bool getTop(T& x);//获取栈顶元素
bool IsEmpty()const{return (this->top==-1 ? true : false);}
bool IsFull()const{return (this->top+1==this->maxSize ? true : false);}
int getSize()const{return this->top+1;}
void MakeEmpty(){this->top = -1;}//使栈空
void print();
friend ostream& operator<<(ostream& out, SeqStack<T>& s)//声明为友元函数,重载输出运算符<<
{
out<<"top = "<<s.top<<endl;
for(int i=0; i<=s.top; ++i)
out<<i<<":"<<s.elements[i]<<endl;
return out;
}
};
template<class T>
void SeqStack<T>::print()
{
if(!this->IsEmpty())
{
for(int i=this->top; i>=0; --i)
cout<<" ["<<this->elements[i]<<"] ";
cout<<endl;
}
}
template<class T>
void SeqStack<T>::Push(const T& x)
{
if(!this->IsFull())
{
++this->top;
this->elements[this->top] = x;
}
else
{
this->overflowProcess();
this->elements[this->top] = x;
++this->top;
}
};
template<class T>
void SeqStack<T>::Pop(T& x)
{
if(!this->IsEmpty())
{
x = this->elements[this->top];
--this->top;
}
};
template<class T>
bool SeqStack<T>::getTop(T& x)
{
if(!this->IsEmpty())
{
x = this->elements[this->top-1];
return true;
}
return false;
};
template<class T>
void SeqStack<T>::overflowProcess()
{
T *newArry = new T[maxSize+stackIncreament];
if(newArry == NULL)
{
cout<<"内存分配失败!"<<endl;
exit(1);
}
for(int i=0; i<this->maxSize; ++i)
newArry[i] = this->elements[i];
this->maxSize = this->maxSize+stackIncreament;
delete[]this->elements;
this->elements = newArry;
};
template<class T>
SeqStack<T>::SeqStack(int sz):top(-1),maxSize(sz)
{
this->elements = new T[this->maxSize];
assert(this->elements != NULL);
}; int main()
{
SeqStack<int> ss;
for(int i=0; i<60; ++i)
ss.Push(i);
int i = int();
ss.Pop(i);
cout<<i<<endl;
ss.print();
cout<<ss<<endl;
return 0;
}
试试执行效果

因为换行过多没有将整幅图上传。
顺序栈(C++)的更多相关文章
- 数据结构:C_顺序栈的实现
数据结构顺序栈的实现(C语言版) 1.写在前面 栈是一种遵循元素先进(Push)后出(Pop)规则的线性表,它的实现可以用数组或者链表. ..... 2.代码分解 2.1对栈的结构定义: typede ...
- D_S 顺序栈的基本操作
// main.cpp #include <iostream> using namespace std; #include "Status.h" typedef in ...
- 数据结构Java实现05----栈:顺序栈和链式堆栈
一.堆栈的基本概念: 堆栈(也简称作栈)是一种特殊的线性表,堆栈的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置进行插入和删除操作,而堆栈只允许在固定一端进行插入和删除 ...
- 01顺序栈_Stack---(栈与队列)
#include "stdio.h" #include "stdlib.h" #include "io.h" #include " ...
- 把十进制整数转换为r(r=2)进制输出(顺序栈实现)
上周的第二个作业补上~~ 上周的要求: 1.给出顺序栈的存储结构定义. 2.完成顺序栈的基本操作函数. 1) 初始化顺序栈 2) 实现入栈和出栈操作 3) 实现取栈顶元素 ...
- 数据结构之顺序栈SqStack
顺序栈SqStack 基本操作 Status InitStack()//构造一个空栈S Status DestroyStack()//销毁栈S,S不再存在 Status ClearStack()//把 ...
- 顺序栈之C++实现
顺序栈就是用顺序表(数组)实现的栈.其组织形式如下图所示: 下面介绍下我用C++实现的顺序栈,在VC6下调试通过.不足之处还请指正. 1.文件组织 2.ss.h栈类的声明及宏的定义 #ifndef _ ...
- 顺序栈和链式栈(C++实现)
顺序栈,是一种基于数组的存储表示. 实现类代码如下: template<class T> class SeqStack{ T *element; int top; int maxSize; ...
- salesforce零基础学习(七十六)顺序栈的实现以及应用
数据结构中,针对线性表包含两种结构,一种是顺序线性表,一种是链表.顺序线性表适用于查询,时间复杂度为O(1),增删的时间复杂度为O(n).链表适用于增删,时间复杂度为O(1),查询的时间复杂度为O(n ...
- 【小白成长撸】--顺序栈(C语言版)
// 顺序栈.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h"//test1.0--栈表仅限Int类型 #include <stdio. ...
随机推荐
- Zabbix 4.4 离线安装 使用mariadb的踩坑,无法停止服务
先分享一个网站,之前就没注意过有这个网站,不知道是啥时候开放的.里面分享了N多zabbix的模板. https://share.zabbix.com/ 报错如下 Unsupported charset ...
- 执行对象Statement、PreparedStatement和CallableStatement详解
执行对象是SQL的执行者,SQL是"安排好的任务",执行对象就是"实际工作的人". 执行对象有三种: Statement.PreparedStatement和C ...
- 大爽Python入门教程 2-3 字符串,列表,字典
大爽Python入门公开课教案 点击查看教程总目录 除了通用的序列方法, 列表和字符串还有些自己的专属方法. 后面介绍有些是英中文对照介绍(英文来自官方文档), 便于大家更深入的去理解其意思. 灵活的 ...
- python-文件操作(一)
目录 文件操作 1.什么是文件? 2.操作文件的方法: 3.路径分类: 4.如何取消特殊字符的功能: 5.对文件的操作有:读.写.追加内容 6.with上下文管理 7.文件操作方法详细: 1.r-读操 ...
- 最大连续子数组和--dp
最大连续子数组和 问题: 给定n个整数(可能为负数)组成的序列a[1],a[2],a[3],-,a[n],求该序列如a[i]+a[i+1]+-+a[j]的子段和的最大值.当所给的整数均为负数时定义子段 ...
- 『学了就忘』Linux软件包管理 — 49、拓展:Linux中通过脚本安装程序
目录 1.脚本程序简介 2.Webmin安装 (1)简介 (2)安装 (3)使用 1.脚本程序简介 脚本程序包并不多见,所以在软件包分类中并没有把它列为一类.它更加类似于Windows下的程序安装,有 ...
- 如何用LOTO示波器TDR方法测试电线长度?
TDR也就是时域反射(Time-domain reflectometer),它可以通过观察导线中反射回来的电信号波形对导线长度进行测量,或者对传输导线的阻抗特性进行分析评估. 我们经常会碰到的TDR的 ...
- 【HTML】标签
HTML标签 2020-09-08 15:37:37 by冲冲 1. 标签 <!DOCTYPE html> <html> <head> <meta cha ...
- 前端jsdebug调试
前端如何像java一样的debug呢? 1.在js页面加入debugger next: function(){ debugger var type=this.quiz[this.progress].s ...
- Redis 很屌,不懂使用规范就糟蹋了
这可能是最中肯的 Redis 使用规范了 码哥,昨天我被公司 Leader 批评了. 我在单身红娘婚恋类型互联网公司工作,在双十一推出下单就送女朋友的活动. 谁曾想,凌晨 12 点之后,用户量暴增,出 ...