C/C++ 数据结构顺序栈的基本操作实现
#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++ 数据结构顺序栈的基本操作实现的更多相关文章
- 数据结构 - 顺序栈的实行(C语言)
数据结构-顺序栈的实现 1 顺序栈的定义 既然栈是线性表的特例,那么栈的顺序存储其实也是线性表顺序存储的简化,我们简称为顺序栈.线性表是用数组来实现的,对于栈这种只能一头插入删除的线性表来说,用数组哪 ...
- 顺序栈的基本操作(C语言)
由于现在只学了C语言所以就写这个C语言版的栈的基本操作 这里说一下 :网上和书上都有这种写法 int InitStack(SqStack &p) &p是取地址 但是这种用法好像C并不 ...
- 数据结构 - 顺序栈的实现 C++
顺序栈封装 C++ 使用C++对顺序栈进行了简单的封装,实现了栈的基本操作 封装方法: pop(),top(),size(),empty(),push() 代码已经过测试 #pragma once # ...
- D_S 顺序栈的基本操作
// main.cpp #include <iostream> using namespace std; #include "Status.h" typedef in ...
- 数据结构——顺序栈(sequence stack)
/* sequenceStack.c */ /* 栈 先进后出(First In Last Out,FILO)*/ #include <stdio.h> #include <stdl ...
- 数据结构--顺序栈--C++实现
#include <iostream> #define MaxSize 5000 using namespace std; template <typename T> clas ...
- 数据结构之顺序栈SqStack
顺序栈SqStack 基本操作 Status InitStack()//构造一个空栈S Status DestroyStack()//销毁栈S,S不再存在 Status ClearStack()//把 ...
- 数据结构——Java实现顺序栈
一.分析 栈是限定仅在表的一端进行插入或删除操作的线性表,对于栈来说,操作端称为栈顶,另一端则称为栈底,栈的修改是按照后进先出的原则进行的,因此又称为后进先出的线性表. 顺序栈是指利用顺序存储结构实现 ...
- 【C#】【数据结构】005-栈:顺序栈
C#数据结构:顺序栈 1.自定义顺序栈结构: /// <summary> /// 顺序栈 /// </summary> /// <typeparam name=" ...
- 数据结构(C实现)------- 顺序栈
栈是限定仅在表的一端进行插入或删除的纯属表,通常称同意插入.删除的一端为栈顶(Top),对应在的.则称还有一端为栈底(Bottom). 不含元素的栈则称为空栈. 所设栈S={a1,a2,a3,..., ...
随机推荐
- 羊了怎么居家办公?免费不限速的远控软件RayLink一解燃眉之急!!
近期疫情放开,各地症状不断的小阳人数量猛增(R君盼望大家早日转阴!!).不论是"羊"后居家,还是天选打工人被迫居家,远程控制公司电脑实现居家办公,成了大部分人的默契选择. 想远程控 ...
- Uncaught ReferenceError: Vue is not defined(之二)
背景最近开发的一个项目,前段时间开发过程中还好好的,最近一次打包部署后,浏览器访问一直是打不开: 打开控制台,看到的一个报错如下: 作为一个前端不太熟练的后端研发,我在网上根据关键字:Vue is n ...
- Job for nfs-server.service failed because the control process exited with error code. See "systemctl status nfs-server.service" and "journalctl -xe" for details.
问题: 解决:
- plsql和instantclient版本都对,依然不能初始化oci.dll解决办法
这里写到 "初始化错误,不能初始化 oci.dll, 请确认你安装的是64位的Oracle客户端 " ,这个描述还是非常的到位啊,我一检查,果然下载的客户端是32位的,在确保自己的 ...
- fabric学习笔记2
fabric学习笔记2 20201303张奕博 2023.1.10 Fabric云服务器搭建 参考视频:视频链接:https://www.bilibili.com/video/BV1gV4y1M7q3 ...
- window批处理一键打开多个exe
使用批处理的start命令,格式为start /d "绝对路径" 目标exe名,记得路径和exe名间有个空格 @echo off start /d "E:\demo\&q ...
- Java流程控制之break、continue、goto
break.continue break在任何循环语句的主体部分,均可用break控制循环的流程.break用于强行退出循环,不执行循环中剩余的语句.(break语句也在switch语句中使用) co ...
- DDD(二)聚合、聚合根、领域服务、应用服务、仓储”和“工作单元”、领域事件、集成事件
DDD(二)聚合.聚合根.领域服务.应用服务.仓储"和"工作单元".领域事件.集成事件 如果觉得样式不好:跳转即可 http://www.lifengying.site/ ...
- Vue CLI创建Vue2项目
1.安装Node.js * Node.js中包含了npm工具 安装后查看版本: node -v npm -v 2.设置npm的源为国内源 npm config set registry https:/ ...
- MYSQL实现排名函数RANK,DENSE_RANK和ROW_NUMBER
1. 排名分类 1.1 区别RANK,DENSE_RANK和ROW_NUMBER RANK并列跳跃排名,并列即相同的值,相同的值保留重复名次,遇到下一个不同值时,跳跃到总共的排名. DENSE_RAN ...