| |
|
|
开发:
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语言实现) -> 正文阅读 |
|
|
[C++知识库]顺序栈及增删改查(c语言实现) |
|
栈是一种特殊的线性表,只能由栈顶进入栈顶删除,即后进先出。(FIFO)类似手电筒放入电池,先放入的只能最后取出。 ?栈可用顺序表和链表两种方式表示即顺序栈和链栈
本文采用两种方式分别建立栈1、以top作为栈顶指针,创建静态数组,初始化top=-1即可 top类似顺序表中length
2、以栈顶与栈底双指针操作,动态开辟空间 后面为方便操作将top指针指向最后元素的后继位置
初始化栈静态数组方式只需要将top=-1。不过多赘述 动态开辟空间方式需先开辟一块空间后将top指针与base指针相等即可。
?入栈操作(即增加)静态数组方式:①?判断栈空间是否满 ,注意下标? ②?栈顶指针+1 ③给数组赋值 注意:因为初始化top从-1开始,因此先++
动态空间方式:①?判断栈空间是否满,,注意判断条件?②? 赋值? ③栈顶指针+1 注意:由图2可知,要保证S.top始终指向空位置,并且S.top-S.base?值小于MAXSIZE
?出栈操作(即删除)静态数组方式:①?判断栈空间是否满 ,注意下标? ②?栈顶指针+1 ③给数组赋值
动态空间方式:①?判断栈空间是否满,注意判断条件?②? 栈顶指针移动? ③?拷贝要删除元素给e
栈改/查栈只能查/改栈顶元素,因此直接将栈顶元素返回或修改即可。 |
|
|
| C++知识库 最新文章 |
| 【C++】友元、嵌套类、异常、RTTI、类型转换 |
| 通讯录的思路与实现(C语言) |
| C++PrimerPlus 第七章 函数-C++的编程模块( |
| Problem C: 算法9-9~9-12:平衡二叉树的基本 |
| MSVC C++ UTF-8编程 |
| C++进阶 多态原理 |
| 简单string类c++实现 |
| 我的年度总结 |
| 【C语言】以深厚地基筑伟岸高楼-基础篇(六 |
| c语言常见错误合集 |
|
|
| 上一篇文章 下一篇文章 查看所有文章 |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| 360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年11日历 | -2025/11/29 4:27:39- |
|
| 网站联系: qq:121756557 email:121756557@qq.com IT数码 |