




全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#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年中国电竞椅行业市场全景评估及发展战略研究报告
- 交通疏导方案(修改)
- 高职智能焊接专业课程改革与实践研究
- 教育数据在招生就业指导中的作用
- 教师心理调适与情绪管理
- 技术创新对产品升级和价格策略的影响分析
- 2023-2028年中国车牌识别系统行业市场发展现状及投资方向研究报告
- 低空经济推动智慧城市建设的路径探索
- 安全检查作业行为规范与专业知识 -改
- 学校信息化建设十五五规划方案
- 2025年保险专业知识能力测试题及答案
- 小学民法典主题班会教案
- 水利工程隐患排查课件
- 办公软件实操试题及详细答案
- 米粉项目可行性分析报告
- 腰痛中医护理查房
- 八五普法自查自评情况报告
- 竞彩资格考试试题及答案
- esg考试试题及答案
评论
0/150
提交评论