全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- GB/T 17774-2025通风机尺寸
- GB/T 8982-2025医用及航空呼吸用氧
- 公司信息通信信息化系统管理员岗位设备安全技术规程
- 公司混合气潜水员岗位职业健康技术规程
- 农艺工岗前核心实操考核试卷含答案
- 金属网制作工安全生产意识考核试卷含答案
- 皮肤科疾病常见症状解析及护理培训
- 2025年沧州黄骅市教师招聘笔试参考试题及答案解析
- 2025年临汾侯马市中小学教师招聘笔试备考试题及答案解析
- 2025年廊坊三河市中小学教师招聘笔试参考题库及答案解析
- 2026年苏州工业职业技术学院单招职业技能测试模拟测试卷及答案解析(夺冠)
- 35kV场内汇流线路工程强制性条文实施管理规程7输电线路工程施工强制执行条文
- 园艺生涯人物访谈总结范文
- 第十六章 《电磁铁与自动控制》知识梳理解析版
- 劲嘉集团SAP项目-业务现状及需求调研报告-FICO-V1.2(中丰田)-20180625
- 文物保护工程资料管理规程
- 优质课点评发言稿(一)
- 2022版HPZ440工作站技术手册指南
- 学术伦理教育与培训
- 迪庆藏族自治州发电有限责任公司新乐水电站环境影响后评价报告书
- 2022秋思想道德与法治学习通超星课后章节答案期末考试题库2023年
评论
0/150
提交评论