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

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

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

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

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

工作原理,一样 先进后出

系统栈,是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指针指向的地址,是最后入栈的元素的位置
相关推荐
禁默4 分钟前
Portainer:让 Docker 管理变简单,用cpolar突破局域网后协作更轻松
java·docker·容器·cpolar
麦兜*8 分钟前
SpringBoot 3.x新特性全面解析:从Java 17支持到GraalVM原生镜像
java·spring boot·后端
一行注释13 分钟前
ECharts柱状图横向展示与DataZoom滑动查看实现
开发语言·前端·javascript
Ulyanov32 分钟前
Impress.js深度解析
开发语言·前端·javascript·css3·impress.js
醇氧35 分钟前
Spring WebFlux 学习
java·学习·spring
烤麻辣烫35 分钟前
23种设计模式(新手)-9单例模式
java·开发语言·学习·设计模式·intellij-idea
ytttr87337 分钟前
基于MATLAB实现时间序列小波相干性分析
开发语言·matlab
资生算法程序员_畅想家_剑魔44 分钟前
Java常见技术分享-设计模式的六大原则
java·开发语言·设计模式
dazzle1 小时前
Python数据结构(五):队列详解
数据结构·python
Howrun7771 小时前
C++ 智能指针_详细解释
开发语言