




已阅读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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 表面处理技术合同
- 城市园林绿化提升合同
- 2025河南郑州大学招聘500人考前自测高频考点模拟试题完整答案详解
- 2025北京大学医学部总务处房地产管理中心宿舍管理员招聘1人考前自测高频考点模拟试题及答案详解(名师系列)
- 2025广东江门市江海区银信资产管理有限公司招聘1人模拟试卷完整答案详解
- 2025贵州民族大学招聘程序招聘博士配偶工作模拟试卷及答案详解(名师系列)
- 2025年河北地质大学选聘工作人员85名模拟试卷及答案详解参考
- 2025福建农信春季招聘194人模拟试卷及答案详解(各地真题)
- 2025鄂托克前旗政府专职消防员招录15名考前自测高频考点模拟试题及答案详解(全优)
- 2025广东珠海市金湾区招聘公办中小学编制内教师160人考前自测高频考点模拟试题有答案详解
- 2025版简易劳务合同模板
- 2025年浙江省单独考试招生语文试卷试题真题(含答案详解)
- 消防水池挖槽施工方案
- 高一地理第一次月考卷02【测试范围:必修一第1~2章】(考试版)
- 水电站设备维护检修课件
- 2025年沼液还田协议书
- 2025年浙商银行招聘考试(综合知识)历年参考题库含答案详解(5卷)
- APQP第三版及CP第一版介绍
- 治安管理处罚法普法讲座
- 六堡茶知识讲座
- 中南财经政法大学哲学院《615社会学原理》历年考研真题汇编(含部分答案)
评论
0/150
提交评论