




已阅读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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 跨公路吊车架梁专项建筑施工组织设计及对策
- 选煤厂生产线自动化控制安全防护方案
- 基础桩基施工技术实施方案
- 保障性住房工程造价与招标管理方案
- 智算中心扩建项目建设工程方案
- 建设工程项目施工合同中的合同备案与行政管理
- 探索货物运输合同中的环保责任与可持续发展战略
- 无共同财产且有子女抚养协议的离婚协议书
- 钢结构设计优化与分析
- 信息技术在护理教学模式创新中的应用研究
- 业务外包作业人员培训管理办法
- 电梯五方通话布线方案
- 物理化学实验B智慧树知到课后章节答案2023年下北京科技大学
- 河南农业大学-毕业答辩PPT模板
- 技术类《核电站通用机械设备》第1部分(阀门)
- 田径运动会竞赛团体总分记录表
- 2023年一级建造师考试《建设工程法规及相关知识》真题及答案
- Analyst软件应用培训教程
- 匀变速直线运动的推论和比例式公开课一等奖市赛课一等奖课件
- 安庆时联新材料有限责任公司10000吨年抗氧剂系列产品及抗紫外线吸收剂生产项目环境影响报告
- 2023学年完整公开课版教学Starsafterthestorm秦菽康
评论
0/150
提交评论