已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
这事c语言栈的几种方法的应用,希望有助于大家学习c#include stdio.h#includestdlib.h#includestring.h#define MAXNUM 20#define ElemType int /*定义顺序栈的存储结构*/typedef struct ElemType stackMAXNUM; int top;SqStack;/*初始化顺序栈*/void InitStack(SqStack *p)if(!p) printf(内存分配失败!);p-top=-1;/*入栈*/void Push(SqStack *p,ElemType x) if(p-toptop=p-top+1; p-stackp-top=x; else printf(Overflow! n);/*出栈*/ElemType Pop(SqStack *p) ElemType x; if(p-top=0) x=p-stackp-top; printf(以前的栈顶数据元素%d已经被删除! n,p-stackp-top); p-top=p-top-1; return x; else printf(Underflow! n); return(0); /*获取栈顶元素*/ElemType GetTop(SqStack *p)ElemType x;if(p-top=0)x=p-stackp-top;printf(n栈顶元素为:%dn,x);return x;elseprintf(Underflow! n);return 0;/*遍历顺序栈*/void OutStack(SqStack *p)int i;printf(n);if(p-toptop;i=0;i-) printf(第%d个数据元素是:%6dn,i,p-stacki);/括号匹配void Pop2(SqStack *p) ElemType x; if(p-top=0) x=p-stackp-top; p-top=p-top-1; void match()SqStack *s;int i=0,flag=1;char c20;getchar();printf(请输入括号和*n);gets(c);s=(SqStack *)malloc(sizeof(SqStack);InitStack(s);while(itop=-1)printf(缺少左括号(n);flag=0;if(s-top!=-1&s-stacks-top=()Pop2(s);break;case:if(s-top=-1)printf(缺少左括号n);flag=0;if(s-top!=-1&s-stacks-top=)Pop2(s);break;case:if(s-top=-1)printf(缺少左括号n);flag=0;if(s-top!=-1&s-stacks-top=)Pop2(s);break;i+;if(s-top=-1&flag)printf(匹配成功n);if(s-top!=-1) printf(%c括号匹配错误,缺少其右括号n,s-stacks-top);/进制转换ElemType Pop1(SqStack *p) ElemType x; if(p-top=0) x=p-stackp-top; p-top=p-top-1; return x; else printf(Underflow! n); return(0); void zhuanhuan()SqStack *s;char a20;int n,number;printf(请输入10进制数字n);scanf(%d,&number);printf(请输入需要转换的进制:n);scanf(%d,&n);s=(SqStack *)malloc(sizeof(SqStack);InitStack(s);while(number)Push(s,number%n);number/=n;printf(转换成%d进制为 :n,n);while(s-top!=-1)if(n10&s-stacks-top9)printf(%c,Pop1(s)-10+A);else printf(%d,Pop1(s);printf(n);/*主函数*/void main()SqStack *q;int cord;ElemType a; printf(第一次使用必须初始化! n); do printf(n); printf(n-主菜单- n); printf(n 1 初始化顺序栈 n); printf(n 2 插入一个元素 n); printf(n 3 删除栈顶元素 n); printf(n 4 取栈顶元素 n); printf(n 5 置空顺序栈 n); printf(n 6 结束程序运行 n); printf(n 7 括号匹配 n); printf(n 8 进制转换 n); printf(n- n); printf(请输入你的选择(1,2,3,4,5,6,7,8); scanf(%d,&cord); printf(n); switch(cord) case 1: q=(SqStack*)malloc(sizeof(SqStack); InitStack(q); OutStack(q); break; case 2: printf(请输入要插入的数据元素:a=); scanf(%d,&a); Push(q,a); OutStack(q); break; case 3: Pop(q); OutStack(q); break; case 4: GetTop(q); OutStack(q); break; case 5:
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 沙滩围堰施工方案(3篇)
- 护理沟通中的同理心应用
- 2025年山东会考化学真题及答案
- 2025年机器人基础考试题及答案
- 2025年广西小学语文试卷及答案
- 失眠的治疗课件
- 再生婚礼策划方案
- 托管护理成本效益分析
- 2025年中考安徽英语试卷及答案
- 国内外疟疾护理研究进展
- 《中医药膳学》考试复习题库(含答案)
- 注浆堵漏防水施工方案范本
- 曲柄滑块机构设计
- 离心泵知识课件
- 雨课堂学堂在线学堂云《船舶安全熟悉培训(大连海大 )》单元测试考核答案
- 2025年南阳市内乡县经投公司招聘试题及答案
- 2025年及未来5年中国压裂车行业市场深度分析及投资战略规划报告
- 2025年《中外教育史》冲刺押题卷(附答案)
- 2025-2026学年大象版小学科学五年级上册期末复习卷及答案
- 采购部年终总结及明年计划
- 中国资源循环集团有限公司子公司招聘笔试题库及答案2025年
评论
0/150
提交评论