#include <iostream>
#include <Windows.h>
using namespace std;
#define MAXSIZE 6
//顺序栈的实现
typedef struct {
int* base;
int* top;
int stacksize;
int Length;
}SQstack;
//初始化
void Initstack(SQstack& S) {
S.base = new int[MAXSIZE];
S.top = S.base;
S.stacksize = MAXSIZE;
S.Length = 0;
}
//入栈
bool InsertStack(SQstack& S,int e) {
if (S.top - S.base == S.stacksize) {
cout << "栈已满,无法入栈!";
return false;
}
//*(S.top++) = e;
*S.top = e;
S.top++;
S.Length++;
return true;
}
//出栈
bool DeleteStack(SQstack& S, int &e) {
if (S.base == S.top) {
cout << "栈为空,无法出栈!" << endl;
return false;
}
S.top--;
e = *S.top;
//e = *(--S.top);
S.Length--;
return true;
}
//获取栈顶元素
void getTop(SQstack& S,int &e) {
e = *(S.top-1);//返回栈顶元素的值,栈顶指针不变
cout <<"栈顶元素为:"<< e << " ";
cout << endl;
}
//判断栈是否为空
bool EmptyStack(SQstack& S) {
return S.base == S.top;
}
//销毁顺序栈
void Destory(SQstack& S) {
if (S.base) {
delete S.base;
S.base = NULL;
}
}
//获取顺序栈的长度
int getLnegth(SQstack& S) {
return S.Length;
}
void showMenu() {
cout << "\t顺序栈的基本操作" << endl;
cout << "0.退出" << endl;
cout << "1.入栈" << endl;
cout << "2.出栈" << endl;
cout << "3.获取栈顶元素" << endl;
cout << "4.判断栈是否为空" << endl;
cout << "5.返回栈的元素个数" << endl;
}
int main() {
SQstack Q;
int choose = 0;
int e = 0;//要入栈的元素
int n = 0;//入栈的元素个数
int e1 = 0;//出栈的元素
int e2 = 0;//栈顶元素
Initstack(Q);
showMenu();
bool flag = -1;
while (flag) {
cout << "请选择:";
cin >> choose;
switch (choose)
{
case 1:
cout << "请输入要入栈的元素个数:";
cin >> n;
while (n > 0) {
cout << "请输入要入栈的元素:";
cin >> e;
if (InsertStack(Q, e)) {
cout << "元素入栈成功!" << endl;
}
else {
cout << "元素入栈失败!" << endl;
}
n--;
}
break;
case 2:
cout << "出栈------" << endl;
if (DeleteStack(Q, e1)) {
cout << "出栈的元素 :" << e1 << endl;
}
break;
case 3:
getTop(Q, e2);
break;
case 4:
if (EmptyStack(Q)) {
cout << "顺序栈为空!" << endl;
}
else {
cout << "顺序栈不为空!" << endl;
}
break;
case 5:
cout << "顺序栈的长度为:" << getLnegth(Q) << endl;
break;
case 0:
default:
cout << "退出系统!" << endl;
flag = 0;
}
} cout << "销毁顺序表----" << endl;
Destory(Q);
system("pause");
return 0;
}

C/C++ 数据结构顺序栈的基本操作实现的更多相关文章

  1. 数据结构 - 顺序栈的实行(C语言)

    数据结构-顺序栈的实现 1 顺序栈的定义 既然栈是线性表的特例,那么栈的顺序存储其实也是线性表顺序存储的简化,我们简称为顺序栈.线性表是用数组来实现的,对于栈这种只能一头插入删除的线性表来说,用数组哪 ...

  2. 顺序栈的基本操作(C语言)

    由于现在只学了C语言所以就写这个C语言版的栈的基本操作 这里说一下 :网上和书上都有这种写法 int InitStack(SqStack &p) &p是取地址  但是这种用法好像C并不 ...

  3. 数据结构 - 顺序栈的实现 C++

    顺序栈封装 C++ 使用C++对顺序栈进行了简单的封装,实现了栈的基本操作 封装方法: pop(),top(),size(),empty(),push() 代码已经过测试 #pragma once # ...

  4. D_S 顺序栈的基本操作

    //  main.cpp #include <iostream> using namespace std; #include "Status.h" typedef in ...

  5. 数据结构——顺序栈(sequence stack)

    /* sequenceStack.c */ /* 栈 先进后出(First In Last Out,FILO)*/ #include <stdio.h> #include <stdl ...

  6. 数据结构--顺序栈--C++实现

    #include <iostream> #define MaxSize 5000 using namespace std; template <typename T> clas ...

  7. 数据结构之顺序栈SqStack

    顺序栈SqStack 基本操作 Status InitStack()//构造一个空栈S Status DestroyStack()//销毁栈S,S不再存在 Status ClearStack()//把 ...

  8. 数据结构——Java实现顺序栈

    一.分析 栈是限定仅在表的一端进行插入或删除操作的线性表,对于栈来说,操作端称为栈顶,另一端则称为栈底,栈的修改是按照后进先出的原则进行的,因此又称为后进先出的线性表. 顺序栈是指利用顺序存储结构实现 ...

  9. 【C#】【数据结构】005-栈:顺序栈

    C#数据结构:顺序栈 1.自定义顺序栈结构: /// <summary> /// 顺序栈 /// </summary> /// <typeparam name=" ...

  10. 数据结构(C实现)------- 顺序栈

    栈是限定仅在表的一端进行插入或删除的纯属表,通常称同意插入.删除的一端为栈顶(Top),对应在的.则称还有一端为栈底(Bottom). 不含元素的栈则称为空栈. 所设栈S={a1,a2,a3,..., ...

随机推荐

  1. flex布局,均分的剩余空间不等分问题

    flex布局:使用flex-grow均分剩余空间,每个盒子都要给个初始宽度,才能均分

  2. Java数组之冒泡排序【重点】

    冒泡排序 冒泡排序是最为出名的排序算法之一,总共有八大排序! 冒泡的代码还是相当简单的,两层循环,外层冒泡轮数,里层依次比较. 我们看到嵌套循环,应该立马就可以得出这个算法的时间复杂度为O(n2). ...

  3. 2022-3-18内部群每日三题-清辉PMP

    1.在评估项目活动现状的会议中,团队发现存在一些影响可交付成果的风险.项目经理应该怎么做? A.跟踪已发现的风险,识别和分析新风险,并评估整个项目的风险过程有效性 B.记录风险管理信息用于经验教训 C ...

  4. Mac如何用鼠标快速锁屏

    锁屏谁不会啊?本来写这篇文章,感觉自己太多余,但用鼠标直接锁屏就有点小意思,Mac对于很多人来说非常模式,通常是商务.设计这类人事在使用,对于新手而言,它的功能过于隐藏,那么Mac要如何达到快速锁屏呢 ...

  5. 第九章 MySQL 高可用(MHA)

    MySQL 高可用(MHA) 一 MHA高可用部署 需要使用的前提: 当普通主从复制不能满足我们的需求,  主节点宕机  影响业务的不间断运行.这里就需要用到MHA 高可用 1. MHA高可用的介绍 ...

  6. DOSBox进行文件操作

    1.使用DOSBox进行汇编语言的学习 2.输入edit进行asm文件编辑,保存后输入masm 文件名.asm,进行编译:输入link 文件名进行连接:输入debug 文件名.exe进行执行,并进行调 ...

  7. nmon 采坑

    1.安装 wget http://sourceforge.net/projects/nmon/files/nmon16g_x86.tar.gz 2.解压 tar -zxvf nmon16g_x86.t ...

  8. dedecms安装使用

    1.运行 http://域名/install/index.php(比如你的域名是:http://www.dede58.com/,就输入http://www.dede58.com/install/ind ...

  9. vue后台管理系统——数据统计模块

    电商后台管理系统的功能--数据统计模块 1. 数据统计概述 数据统计模块主要用于统计电商平台运营过程的中的各种统计数据,并通过直观的可视化方式展示出来,方便相关运营和管理人员查看. 2. 用户来源数据 ...

  10. 06 显示fps帧频

    需要看fps就用下面这段代码即可 var FPS = {};FPS.time = 0;FPS.FPS = 0; FPS.startFPS = function (stage){ FPS.shape = ...