当前位置: 首页 > news >正文

【数据结构】“栈”的模拟实现

在这里插入图片描述

💐 🌸 🌷 🍀 🌹 🌻 🌺 🍁 🍃 🍂 🌿 🍄🍝 🍛 🍤
📃个人主页 :阿然成长日记 👈点击可跳转
📆 个人专栏: 🔹数据结构与算法🔹C语言进阶
🚩 不能则学,不知则问,耻于问人,决无长进
🍭 🍯 🍎 🍏 🍊 🍋 🍒 🍇 🍉 🍓 🍑 🍈 🍌 🍐 🍍

文章目录

  • ⭐️一、什么是栈
  • 💬二、栈的分类
  • 📅三、用动态数组实现栈
    • 1.栈的结构体定义
    • 2.初始化
    • 3.栈的销毁
    • 4.压栈
    • 5.出栈
    • 6.获取栈顶元素
    • 7.获取栈内元素
    • 判断栈是否为空

⭐️一、什么是栈

:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。

🔸压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈顶。
🔸出栈:栈的删除操作叫做出栈。出数据也在栈顶

在这里插入图片描述

💬二、栈的分类

1️⃣ Ⅰ 顺序存储结构
在这里插入图片描述
实用性不高。
2️⃣ Ⅱ 链式存储结构
在这里插入图片描述

📅三、用动态数组实现栈

使用动态内存管理函数,实现数组动态化。有关动态内存函数的详细讲解可点击查看
👉 内存函数详解

1.栈的结构体定义

注意:这里我们将栈顶初始化是-1。你也可以是0;
代码:

typedef int STDataType;
typedef struct Stack
{STDataType* a;int top;int capacity;
}ST;

2.初始化

代码:

//初始化
void STInit(ST* p)
{p->a = NULL;p->capacity = 0;p->top = 0;
}

3.栈的销毁

代码:

//栈的销毁
void STDesdroy(ST* p)
{assert(p);free(p->a);p->a = NULL;p->capacity = p->top = 0;
}

4.压栈

代码:

//压栈
void STPush(ST* p, STDataType x)
{assert(p);//开辟空间if (p->capacity = p->top){int newcapacity = p->capacity == 0 ? 4 : p->capacity * 2;//开辟空间个数 STDataType* tmp = (STDataType*)realloc(p->a, sizeof(STDataType) * newcapacity);//开辟if (tmp == NULL){perror("realloc fail\n");}p->a = tmp;//将开辟好的空间指回原指针p->capacity = newcapacity;}p->a[p->top] = x;p->top++;
}

5.出栈

代码:

//出栈
void STPop(ST* p)
{assert(p);assert(p->top >= 0);p->top--;
}

6.获取栈顶元素

//获取栈顶元素
STDataType STTop(ST* p)
{assert(p);assert(p->top > 0);return p->a[p->top];
}

7.获取栈内元素

//大小
int STSize(ST* p)
{assert(p);return p->top;
}

判断栈是否为空

代码:

//是否为空
bool STisEmpty(ST* p)
{if (p->top == 0){return false;}return true;
}
http://www.lryc.cn/news/125688.html

相关文章:

  • 12 注册登录
  • 动态规划之最长上升子序列模板
  • Python源码05:使用Pyecharts画词云图图
  • MariaDB 10.11.4 安装教程(zip格式,Windows环境)
  • 【Python国内源】pip换源终极方法【Windows】
  • 【elementUi】绘制自定义表格、绘制曲线表格
  • 使用 Python 中的 Langchain 从零到高级快速进行工程
  • 神经网络基础-神经网络补充概念-07-使用计算图求导
  • docker常用指令
  • 【金融量化】对企业进行估值的方法有哪些?
  • Qt+C++自定义控件仪表盘动画仿真
  • 怎样让音频速度变慢?请跟随以下方法进行操作
  • 【C语言】常用的库和作用以及对应的函数
  • Android 12.0 系统systemui下拉通知栏的通知布局相关源码分析
  • java实现docx,pdf文件动态填充数据
  • 【Python2】实现异步进程的创建、终止与资源回收
  • leetcode做题笔记79单词搜索
  • http库 之 OKHttpUtil
  • gitlab合并新项目和分支切换
  • WebStorm修改默认打开的浏览器
  • vue3+vite+pinia
  • ROSpider机器人评测报告
  • 在vue3 中,使用element-plus中的el-scrollbar,让内容元素自动滚动
  • Redis——Redis.conf详解+Redis持久化(RDB和AOF)+Redis订阅发布
  • 16.1.2 Linux 的多用户多任务环境
  • 【11】Redis学习笔记 (微软windows版本)【Redis】
  • 数据结构刷题训练:用栈实现队列(力扣OJ)
  • 数字化车间mes生产执行管理系统
  • SpringBoot + Mybatis多数据源
  • ad+硬件每日学习十个知识点(35)23.8.15 (接口电路:RS232、RS485、RS422,单线协议UART->TTL)