栈的操作C语言.doc_第1页
栈的操作C语言.doc_第2页
栈的操作C语言.doc_第3页
栈的操作C语言.doc_第4页
栈的操作C语言.doc_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

C 语言实现 栈的各种操作,调试运行成功有截图。后附代码。代码: #include #include#include #define INIT_SIZE 5 /初始大小 #define INCREASE_SIZE 5 /每次增加大小 typedef struct int *top; int *base; int stacksize;sqstack; /这是一个栈的结构体 int Creat_stack(sqstack*s);int Gettop_stack(sqstack*s,int *e);int Pop_stack(sqstack*s,int*e);int Push_stack(sqstack*s,int e);int Destroy_stack(sqstack*s);int Getsize_stack(sqstack*s);void main() int m,e,n,f,i,f1,k=0; int a1,a2,a3,a4,a5,a6,a7;/是用来接函数的返回值的 int *e1,*e2,*e3; sqstack ss;ss.base =ss.top =NULL;/初始化 e1=e2=e3=&k; /指针声明时最好初始化一下,若果没有初始化,直接*e1,是错误的 printf(-顺序栈的基本操作-n); printf(-1.创建一个空栈-n); printf(-2.销毁栈-n); printf(-3.单个入栈-n); printf(-4.单次出栈-n); printf(-5.查询栈顶元素-n); printf(-6.多数入栈-n); printf(-7.集体出栈-n); printf(-8.查询栈容量-n); printf(-9.退出-n); loop: printf(请选择:n); scanf(%d,&m); switch(m) case 1: a1=Creat_stack(&ss); if(a1=0) printf(栈已经存在,请先销毁原栈!n); break; printf(OK!已经成功建立一个空栈!n); break; case 2: a5=Destroy_stack(&ss); if(a5=0) printf(栈不存在!n); break; else printf(OK!销毁成功!n); break; case 3: printf(请输入你要入栈的元素(整型):n); scanf(%d,&e); a2=Push_stack(&ss,e); if(a2=0) printf(栈不存在,请先创建栈!n); break; printf(OK!入栈成功!n); break;case 4: a3=Pop_stack(&ss,e1); if(a3=-1) printf(栈不存在,请先创建栈!n); break; else if(a3=0) printf(栈为空!n); break; else printf(OK!出栈成功!出栈元素为:); printf(%d,*e1); break; case 5: a4=Gettop_stack(&ss,e2); if(a4=-1) printf(栈不存在,请先创建栈!n); break; else if(a4=0) printf(栈为空!n); break; else printf(OK!查询栈顶元素为:); printf(%dn,*e2);break; case 6: printf(请输入您要入栈的个数:n); scanf(%d,&n);for(i=0;ibase !=s-top ) return 0; s-base=(int*)malloc(INIT_SIZE*sizeof(int); / base 本来是指向int型的指针,若把后面一长串内存强制为int则划分为一小块一小块 /base+ 也变为指向下一个int型 s-top =s-base; s-stacksize=INIT_SIZE; return 1;int Gettop_stack(sqstack*s,int*e) if(s-base=NULL) return -1; else if(s-base=s-top) return 0; else *e=*(s-top-1);/ 这个top指针没有改变 return 1;int Push_stack(sqstack*s,int e) if(s-base =NULL) return 0;/栈不存在if(s-top-s-base)=s-stacksize ) s-base=(int*)realloc(s-base,(s-stacksize+INCREASE_SIZE)*sizeof(int); /realloc 增加一段内存 s-stacksize+=INCREASE_SIZE ; s-top =s-base+s-stacksize;/确保top指向栈顶,之前top超了范围, *(s-top)=e; s-top +; return 1;int Pop_stack(sqstack*s,int*e) if(s-base=NULL) return -1; else if(s-top=s-base) return 0; else s-top-; *e=*(s-top);/要先降低top,再返回,top已经改变 return 1; int Destroy_stack(sqstack*s) if(s-base =NULL) return 0;/栈不存在 free

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论