• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > C语言 栈的表示和实现详细介绍

C语言 栈的表示和实现详细介绍

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了c语言栈,c语言栈的实现,c语言栈是什么,顺序栈c语言实现,链栈c语言实现等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

C语言 栈的表示和实现详细介绍

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

栈作为一种数据结构,是一种只能在一端进行插入和删除操作的特殊线性表。它按照先进后出的原则存储数据,先进入的数据被压入栈底,最后的数据在栈顶,需要读数据的时候从栈顶开始弹出数据(最后一个数据被第一个读出来)。栈具有记忆作用,对栈的插入与删除操作中,不需要改变栈底指针。

栈是允许在同一端进行插入和删除操作的特殊线性表。允许进行插入和删除操作的一端称为栈顶(top),另一端为栈底(bottom);栈底固定,而栈顶浮动;栈中元素个数为零时称为空栈。插入一般称为进栈(PUSH),删除则称为退栈(POP)。栈也称为后进先出表。

以上定义是在经典计算机科学中的解释。

在计算机系统中,栈则是一个具有以上属性的动态内存区域。程序可以将数据压入栈中,也可以将数据从栈顶弹出。在i386机器中,栈顶由称为esp的寄存器进行定位。压栈的操作使得栈顶的地址减小,弹出的操作使得栈顶的地址增大。

栈在程序的运行中有着举足轻重的作用。最重要的是栈保存了一个函数调用时所需要的维护信息,这常常称之为堆栈帧或者活动记录。堆栈帧一般包含如下几方面的信息:

1.函数的返回地址和参数

2.临时变量:包括函数的非静态局部变量以及编译器自动生成的其他临时变量

实现

 #define STACK_INIT_SIZE 10 /* 存储空间初始分配量 */
 #define STACKINCREMENT 2 /* 存储空间分配增量 */
 typedef struct SqStack
 {
  SElemType *base; /* 在栈构造之前和销毁之后,base的值为NULL */
  SElemType *top; /* 栈顶指针 */
  int stacksize; /* 当前已分配的存储空间,以元素为单位 */
 }SqStack; /* 顺序栈 */
Status InitStack(SqStack *S)
 { /* 构造一个空栈S */
  (*S).base=(SElemType *)malloc(STACK_INIT_SIZE*sizeof(SElemType));
  if(!(*S).base)
   exit(OVERFLOW); /* 存储分配失败 */
  (*S).top=(*S).base;
  (*S).stacksize=STACK_INIT_SIZE;
  return OK;
 }

 Status DestroyStack(SqStack *S)
 { /* 销毁栈S,S不再存在 */
  free((*S).base);
  (*S).base=NULL;
  (*S).top=NULL;
  (*S).stacksize=0;
  return OK;
 }

 Status ClearStack(SqStack *S)
 { /* 把S置为空栈 */
  (*S).top=(*S).base;
  return OK;
 }

 Status StackEmpty(SqStack S)
 { /* 若栈S为空栈,则返回TRUE,否则返回FALSE */
  if(S.top==S.base)
   return TRUE;
  else
   return FALSE;
 }

 int StackLength(SqStack S)
 { /* 返回S的元素个数,即栈的长度 */
  return S.top-S.base;
 }

 Status GetTop(SqStack S,SElemType *e)
 { /* 若栈不空,则用e返回S的栈顶元素,并返回OK;否则返回ERROR */
  if(S.top>S.base)
  {
   *e=*(S.top-1);
   return OK;
  }
  else
   return ERROR;
 }

 Status Push(SqStack *S,SElemType e)
 { /* 插入元素e为新的栈顶元素 */
  if((*S).top-(*S).base>=(*S).stacksize) /* 栈满,追加存储空间 */
  {
   (*S).base=(SElemType *)realloc((*S).base,((*S).stacksize+STACKINCREMENT)*sizeof(SElemType));
   if(!(*S).base)
    exit(OVERFLOW); /* 存储分配失败 */
   (*S).top=(*S).base+(*S).stacksize;
   (*S).stacksize+=STACKINCREMENT;
  }
  *((*S).top)++=e;
  return OK;
 }

 Status Pop(SqStack *S,SElemType *e)
 { /* 若栈不空,则删除S的栈顶元素,用e返回其值,并返回OK;否则返回ERROR */
  if((*S).top==(*S).base)
   return ERROR;
  *e=*--(*S).top;
  return OK;
 }

 Status StackTraverse(SqStack S,Status(*visit)(SElemType))
 { /* 从栈底到栈顶依次对栈中每个元素调用函数visit()。 */
  /* 一旦visit()失败,则操作失败 */
  while(S.top>S.base)
   visit(*S.base++);
  printf("\n");
  return OK;
 }
 #include"c1.h"
 typedef int SElemType; /* 定义栈元素类型,此句要在c3-1.h的前面 */
 #include"c3-1.h"
 #include"bo3-1.c"

 Status visit(SElemType c)
 {
  printf("%d ",c);
  return OK;
 }

 void main()
 {
  int j;
  SqStack s;
  SElemType e;
  if(InitStack(&s)==OK)
   for(j=1;j<=12;j++)
    Push(&s,j);
  printf("栈中元素依次为:");
  StackTraverse(s,visit);
  Pop(&s,&e);
  printf("弹出的栈顶元素 e=%d\n",e);
  printf("栈空否:%d(1:空 0:否)\n",StackEmpty(s));
  GetTop(s,&e);
  printf("栈顶元素 e=%d 栈的长度为%d\n",e,StackLength(s));
  ClearStack(&s);
  printf("清空栈后,栈空否:%d(1:空 0:否)\n",StackEmpty(s));
  DestroyStack(&s);
  printf("销毁栈后,s.top=%u s.base=%u s.stacksize=%d\n",s.top,s.base, s.stacksize);
 }

</div>

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C语言数据结构 栈的基础操作
  • C语言中函数参数的入栈顺序详解及实例
  • C语言 表、栈和队列详解及实例代码
  • 使用C语言判断栈的方向实例
  • C语言 栈的表示和实现详细介绍
  • C语言对栈的实现基本操作
  • C语言 数据结构中栈的实现代码
  • 如何用C语言、Python实现栈及典型应用
  • 浅析C语言中堆和栈的区别
  • 使用C语言来解决循环队列问题的方法

相关文章

  • 2017-05-28linux下实现的2048游戏示例分享
  • 2017-05-28如何使用VC库函数中的快速排序函数
  • 2017-05-28C++的template模板中class与typename关键字的区别分析
  • 2017-05-28详解C++的模板中typename关键字的用法
  • 2017-05-28深入理解atoi()与itoa()函数的用法
  • 2017-05-28C++多继承同名隐藏实例详细介绍
  • 2017-05-28C++ 网络编程 总结
  • 2017-05-28汇编语言常见错误信息中文注解
  • 2017-05-28c++中数字与字符串之间的转换方法(推荐)
  • 2017-05-28C基础 寻找随机函数的G点详解

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C语言 数与串之间转换的方法
    • 深入理解c++中char*与wchar_t*与string以及wstring之间的相互转换
    • C语言构建动态数组完整实例
    • 优秀程序员必须知道的20个位运算技巧
    • C语言以数据块的形式读写文件实例代码
    • 基于C语言实现的贪吃蛇游戏完整实例代码
    • C++函数模板与类模板实例解析
    • 四叉树有损位图压缩处理程序示例
    • C语言编写获取Linux本地目录及本机信息的小程序实例
    • 用C语言判断字符是否为空白字符或特殊字符的方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有