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++知识库]顺序栈的基本操作

栈是一种运算受限的线性表,是一种先进后出的数据结构,限定只能在一端进行插入和删除操作,允许操作的一端称为栈顶,不允许操作的称为栈底

顺序栈的实现是十分简单的跟顺序表的顺序存储基本一致

顺序栈的基本操作如下:

#include<stdio.h>
#include<stdlib.h>
#define MaxSize 50//顺序栈的初始空间
#define Stackcream 10//存储空间分配增量

typedef struct
{
	int data[MaxSize];//初始化top指向-1
	int top;//指示当前栈顶位置
}Sqtack;//顺序栈
void InitStack(Sqtack &stack)
{
	stack.top = -1;//初始状态为-1也可以指向0在相关操作有一些变动
}
bool STackEmpty(Sqtack stack)//判栈空
{
	if (stack.top == -1)
		return false;
	else
		return true;
}
int GetLength(Sqtack &stack)
{
	return stack.top + 1;//因为栈顶指针为top初始指向-1所以元素个数为top+1;
}
int Push(Sqtack &stack, int x)
{
	if (stack.top == MaxSize - 1)//栈满报错
		return 0;
	stack.data[++stack.top] = x;//栈顶指针加1入栈
	return 1;
}
int Pop(Sqtack &stack, int &x)//弹出栈顶元素
{
	if (stack.top == -1)//如果为栈底什么也不做
		return 0;
	x = stack.data[stack.top--];
	return true;

}
int GetTop(Sqtack &stack, int &x)
{
	if (stack.top == -1)
		return 0;
	x = stack.data[stack.top];
	return 1;
	
}
void traverse(Sqtack stack)//遍历栈中所有元素
{
	int i = 0;
	while (i <= stack.top)
	{
		printf("%d\n", stack.data[i++]);
	}
}
void getTop(Sqtack &stack, int *e)//获得栈顶元素
{
	if (stack.top == -1)
		return;
	else
		*e = stack.data[stack.top];
	
}
int main()
{
	Sqtack stack;
	InitStack(stack);
	STackEmpty(stack);
	int i = 0;
	int x;
	int e=0;
	int j;
	for (; i < 5; i++)
	{
		printf("请输入入栈的元素:\n");
		scanf_s("%d", &x);
		Push(stack, x);
	}
	traverse(stack);

	printf("栈的长度为%d\n", GetLength(stack));
	GetTop(stack, e);
	printf("栈顶元素为%d\n",e);
	printf("出栈元素:\n");
	Pop(stack, j);
	printf("出栈后\n");
	traverse(stack);

}

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-09-20 15:36:17  更:2021-09-20 15:38:54 
 
开发: 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/23 23:03:01-

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