c语言栈的几种方法应用

上传人:自*** 文档编号:80156285 上传时间:2019-02-18 格式:DOC 页数:7 大小:86.50KB
返回 下载 相关 举报
c语言栈的几种方法应用_第1页
第1页 / 共7页
c语言栈的几种方法应用_第2页
第2页 / 共7页
c语言栈的几种方法应用_第3页
第3页 / 共7页
c语言栈的几种方法应用_第4页
第4页 / 共7页
c语言栈的几种方法应用_第5页
第5页 / 共7页
点击查看更多>>
资源描述

《c语言栈的几种方法应用》由会员分享,可在线阅读,更多相关《c语言栈的几种方法应用(7页珍藏版)》请在金锄头文库上搜索。

1、这事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-t

2、op+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;pri

3、ntf(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;getcha

4、r();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-to

5、p=)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进制

6、数字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;

7、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);

8、 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: printf(n顺序栈被置空! n); OutStack(q); break; case 6: exit(0);case 7:match();break;case 8:zhuanhuan();break; while(cord=8);运行结果截图:

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 其它办公文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号