已阅读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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年通辽辅警招聘考试题库附答案详解(完整版)
- 2025年百色辅警协警招聘考试备考题库含答案详解(b卷)
- 2025年芜湖辅警协警招聘考试备考题库及1套参考答案详解
- 2025年辽源辅警协警招聘考试备考题库及1套完整答案详解
- 2025年鹤壁辅警招聘考试真题附答案详解(完整版)
- 2025年郑州辅警招聘考试题库及答案详解(典优)
- 2025年盐城辅警协警招聘考试备考题库(含答案详解)
- 2025年阜阳辅警协警招聘考试真题及答案详解(夺冠系列)
- 2025年眉山辅警招聘考试真题及答案详解参考
- 2025年鄂州辅警协警招聘考试备考题库及答案详解一套
- 2025山东德德州天衢建设发展集团有限公司招聘工作人员20人笔试考试参考试题及答案解析
- 标准离婚协议书文档模板
- 装修挂靠协议合同范本
- 2025年高考生物试题(重庆卷) 含答案
- 拆除工程专项方案
- 2025年全国低压电工证理论考试笔试试题(200题)附答案
- 2026环艺省考试题及答案
- Unit4+Exploring+Poetry+Reading+课件-2025-2026学年高中英语译林版选择性必修第一册
- 城南旧事导读课件
- 玻璃升降器拆装与检修课件
- T-CSER007-2024煤基固废人造土壤基质用于盐碱地改良的技术规范编制说明
评论
0/150
提交评论