




全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#include #include #include /函数结果状态代码#define TRUE 1#define FALSE 0#define OK 1#define ERROR 0#define INFEASIBLE -1#define OVERFLOW -2/Status 是函数的类型,其值是函数结果状态代码typedef int Status;typedef int SetElemType;typedef SetElemType ElemType;#include tou.h#include #include typedef char SElemType; / 栈的元素类型#define STACK_INIT_SIZE 100 / 存储空间初始分配量 #define STACKINCREMENT 10 / 存储空间分配增量 / 栈的顺序存储表示 P46 typedef struct SqStack SElemType *base; / 在栈构造之前和销毁之后,base的值为NULL SElemType *top; / 栈顶指针 int stacksize; / 当前已分配的存储空间,以元素为单位 SqStack; / 顺序栈/ 构造一个空栈S。int InitStack(SqStack *S) / 为栈底分配一个指定大小的存储空间 (*S).base = (SElemType *)malloc(STACK_INIT_SIZE*sizeof(SElemType); if( !(*S).base ) exit(OVERFLOW); / 存储分配失败 (*S).top = (*S).base; / 栈底与栈顶相同表示一个空栈 (*S).stacksize = STACK_INIT_SIZE; return 1;/ 若栈S为空栈(栈顶与栈底相同的),则返回1,否则返回0。int StackEmpty(SqStack S) if(S.top = S.base) return 1; else return 0;/ 插入元素e为新的栈顶元素。int Push(SqStack *S, SElemType e) if(*S).top - (*S).base = (*S).stacksize) / 栈满,追加存储空间 (*S).base = (SElemType *)realloc(*S).base, (*S).stacksize + STACKINCREMENT) * sizeof(SElemType); if( !(*S).base ) exit(0); / 存储分配失败 (*S).top = (*S).base+(*S).stacksize; (*S).stacksize += STACKINCREMENT; *(*S).top)+=e; / 这个等式的+ * 优先级相同,但是它们的运算方式,是自右向左 return 1;/ 若栈不空,则删除S的栈顶元素,用e返回其值,并返回1;否则返回0。int Pop(SqStack *S,SElemType *e) if(*S).top = (*S).base) return 0; *e = *-(*S).top; / 这个等式的+ * 优先级相同,但是它们的运算方式,是自右向左 return 1;/ 销毁栈S,S不再存在。int DestroyStack(SqStack *S) free(*S).base); /释放栈底的空间,并置空 (*S).base = NULL; (*S).top = NULL; (*S).stacksize = 0; return 1;/ 把S置为空栈。int ClearStack(SqStack *S) (*S).top = (*S).base; /栈底栈顶相同为空栈 return 1;/ 返回S的元素个数,即栈的长度。int StackLength(SqStack S) / 栈顶指针减去栈底指针刚好等于长度,因为栈顶指针指向当前栈 / 顶元素的下一个位置。 return S.top - S.base;/ 若栈不空,则用e返回S的栈顶元素,并返回1;否则返回0。int GetTop(SqStack S,SElemType *e) if(S.top S.base) *e = *(S.top-1); / 栈顶指针的下一个位置为栈顶元素 return 1; else return 0;/ 从栈底到栈顶依次对栈中每个元素调用函数visit()。int StackTraverse(SqStack S,int(*visit)(SElemType) while(S.topS.base) visit(*S.base+); printf(n); return 1;int visit(SElemType c) printf(%d ,c); return 1;#include toutou.hint main() int j,n,num; SqStack s; SElemType e; / 创建一个顺序栈。 if(InitStack(&s) = 1) printf(顺序栈创建成功!n); / 查看栈的长度。 printf(栈的长度是%dn, StackLength(s); / 查看栈是否为空。 printf(栈空否:%d(1:空 0:否)n,StackEmpty(s); / 初始化栈。printf(输入数据个数 :);scanf(%d,&n);printf(输入数据 :);for(j = 1; j = n; j+)scanf(%d,&num);Push(&s, num); printf(栈中元素依次为:); StackTraverse(s,visit); Pop(&s,&e); printf(弹出的栈顶元素 e=%dn,e); GetTop(s,&e); printf(栈顶元素 e=%d
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 物业管理收费及服务标准制定指南
- 医疗器械注册申报关键环节
- 制造企业岗位职责规范及绩效考核
- 企业劳动争议处理流程与委员会制度
- 广告行业实务教学课程标准
- 美容院店铺管理咨询方案
- 2025至2030全球及中国药品分销软件行业产业运行态势及投资规划深度研究报告
- 广西负债法律咨询方案公示
- 咨询配套方案怎么写好呢
- 六一活动大餐活动方案策划
- 医师定考一般程序试题及答案2025年
- 第二单元混合运算单元测试卷(含答案) 2025-2026学年人教版三年级数学上册
- 院感医疗废物知识培训课件
- 2025至2030中国航空保险行业项目调研及市场前景预测评估报告
- 肺癌脑膜转移中国专家共识(2025)解读 4
- 中专院校普法课件
- 水泵检修基础知识培训课件
- 基于stm32的公司考勤系统设计
- 2025版门头广告位租赁及装修合同范本
- 废旧鞋材回收利用-洞察及研究
- 男性私密培训课件
评论
0/150
提交评论