深入解析栈:数据结构与系统栈

定义:栈是限定仅在表尾进行插入和删除操作的线性表

特性:先进后出,后进先出

应用:递归,回溯问题,和优先级有关的问题

区别:数据结构中的栈和系统中栈的关系

工作原理,一样 先进后出

系统栈,是0-3G内存中的一段(8M),存储函数的调用关系,局部变量,参数,返回地址

数据结构栈,内存空间在堆空间开辟。适用场景更广

  1. 栈顶:允许操作的一端
  2. 栈底:不允许操作的一端
  3. 入栈,出栈

栈的存放方式

  1. 顺序存储
  1. 链式存储

  2. // 适配器

  3. #ifndef LINKSTACK_H

  4. #define LINKSTACK_H

  5. typedef struct person

  6. {

  7. char c;

  8. int row;

  9. int col;

  10. } DATATYPE;

  11. typedef struct stacknode

  12. {

  13. DATATYPE data;

  14. struct stacknode *next;

  15. } LinkStackNode;

  16. typedef struct

  17. {

  18. LinkStackNode *top;

  19. int clen;

  20. } LinkStack;

  21. 栈的分类

  22. LinkStack* CreateLinkStack();

  23. int PushLinkStack(LinkStack*ls,DATATYPE*newdata);

  24. int PopLinkStack(LinkStack*ls);

  25. DATATYPE* GetTopLinkStack(LinkStack*ls);

  26. int GetSizeLinkStack(LinkStack*ls);

  27. int IsEmptyLinkStack(LinkStack*ls);

  28. int DestroyLinkStack(LinkStack*ls);

  29. #endif

栈的分类

  1. 1 空增栈
  2. 2 空减栈
  3. 3 满增栈
  4. 4 满减栈
  5. 增栈,新增元素元素后。Top指向的内存地址慢慢变大
  6. 减栈,新增元素元素后。Top指向的内存地址慢慢变小
  7. 空栈, top指针指向的地址,是新元素待插入的位置
  8. 满栈, top指针指向的地址,是最后入栈的元素的位置
相关推荐
HyperAI超神经2 分钟前
在线教程|DeepSeek-OCR 2公式/表格解析同步改善,以低视觉token成本实现近4%的性能跃迁
开发语言·人工智能·深度学习·神经网络·机器学习·ocr·创业创新
晚霞的不甘9 分钟前
CANN 编译器深度解析:UB、L1 与 Global Memory 的协同调度机制
java·后端·spring·架构·音视频
SunnyDays101110 分钟前
使用 Java 冻结 Excel 行和列:完整指南
java·冻结excel行和列
R_.L12 分钟前
【QT】常用控件(按钮类控件、显示类控件、输入类控件、多元素控件、容器类控件、布局管理器)
开发语言·qt
Zach_yuan21 分钟前
自定义协议:实现网络计算器
linux·服务器·开发语言·网络
摇滚侠22 分钟前
在 SpringBoot 项目中,开发工具使用 IDEA,.idea 目录下的文件需要提交吗
java·spring boot·intellij-idea
爱敲代码的TOM26 分钟前
数据结构总结
数据结构
云姜.26 分钟前
java多态
java·开发语言·c++
李堇29 分钟前
android滚动列表VerticalRollingTextView
android·java
CoderCodingNo36 分钟前
【GESP】C++五级练习题 luogu-P1865 A % B Problem
开发语言·c++·算法