




已阅读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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 现代汉语写作的常用技巧试题及答案
- WPS数据导入的一级考试试题及答案
- 文学与美学研究的整合探讨试题及答案
- 多渠道业务模式与风险管理的结合试题及答案
- 2025年逻辑与伦理道德试题及答案
- 普通逻辑的学习效果评估试题及答案
- 计算机一级考试在线学习资源试题及答案
- 如何高效备考2025年逻辑考试试题及答案
- 计算机一级wps备考经验试题及答案
- WPS图文并茂技巧2025年考试要点试题及答案
- 湖北省武汉市2025届高中毕业生四月调研考试数学试卷及答案(武汉四调)
- 《民事诉讼法》 本科课件第16章 简易程序
- 标准名称中华人民共和国卫生部救护车专业标准
- 混凝土搅拌站风险辨识与预防措施
- 财税实务金融企业贷款损失准备金税前扣除的误区
- 各品牌挖掘机挖斗斗轴、马拉头尺寸数据
- 服装测量方法及图示
- 护理基层岗位练兵和技能竞赛---护理试题解答
- 合同审查的注意事项PPT课件
- 如何上好复习课.PPT
- 幼儿园小朋友认识医生和护士.ppt
评论
0/150
提交评论