全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实验三 栈和队列的算法实现(栈)一、实验目的1.掌握栈这种数据结构特性及其主要存储结构。2.掌握栈的基本操作算法。二实验指导(1)程序的三部分构架:1、常量定义(#define),类型定义(typedef)及函数原型定义(#include);2、算法函数,即InitStack、StackEmpty、Push和Pop、等3、主函数。(2)栈的顺序存储结构typedef struct ElemType aMAXSIZE; /* 一维数组子域 */ int top; /* 栈顶指针子域 */ SqStack; /* 栈的顺序结构体类型 */(3)栈的特点:后进先出(4)在实例中,判栈空条件:s.top=-1;判栈满条件:s.top=MAXSIZE-1;进栈操作:先加后压;出栈操作:先弹后减。三、实例栈的顺序存储结构及实现(代码)#include #include #define MAXSIZE 20 /* 数组最大界限 */typedef int ElemType; /* 数据元素类型 */typedef struct ElemType aMAXSIZE; /* 一维数组子域 */ int top; /* 栈顶指针子域 */ SqStack; /* 栈的顺序结构体类型 */SqStack s1;/* 函数声明 */void init_s(SqStack *s);void out_s(SqStack s);void push(SqStack *s,ElemType e);/ElemType pop(SqStack *s);/* 主函数 */Void main() int k; ElemType e; char ch; init_s( &s1); /* 初始化一个空栈 */ do printf(nnn); printf(nn 1. 数据元素e进栈 ); printf(nn 2. 出栈一个元素,返回其值); printf(nn 3. 结束程序运行); printf(n=); printf(n 请输入您的选择 (1,2,3); scanf(%d,&k); switch(k) case 1: printf(n 进栈 e=?); scanf(%d,&e); push( &s1,e); out_s( s1 ); break; / case 2: x= pop( &s1); / printf(n出栈元素 : %d, x); / out_s( s1 ); / break; case 3: exit(0); /* switch */ printf(n -); while(k=1 & ktop=-1; /* init_s */* 输出栈的内容 */void out_s(SqStack s) char ch; int i; /* 千万不能修改栈顶指针top */ if (s.top=-1) printf(“n Stack is NULL. “); else i=s.top; while( i!=-1) printf(“n data=%d”, s.ai); i-; printf(“n 打回车键,继续。“); ch=getchar(); /* out_c */* 进栈函数 */void push(SqStack *s,ElemType e) if(s-top=MAXSIZE-1)printf(“n Sstack is Overflow!”); else s-top+ ; s-as-top=e; /* push */四、实验内容与要求实例中给出了栈的顺序存储结构上的栈初始化、压栈及输出栈元素等基本操作,并给出了测试函数(主函数)。现要求:1.验证以上基本操作;2.设计出栈函数pop(SqSt
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 安全生产知识考试题库(附答案)
- 2026届广西合浦县中考考前最后一卷语文试卷含解析
- 2026年浦发银行春季校园招聘笔试真题
- 劳动防护用品隐患排查评估整治技术指南(2025年版)
- 《秋天》教学设计-2025-2026学年语文一年级上册统编版
- 2026年计算机网络实习报告4篇
- 海泰发展贯彻落实三重一大制度情况自查总结
- 2026年8月证券投资顾问业务考试真题答案
- 第三者责任保险合同
- 2026届辽宁省大石桥市水源镇九一贯制校中考语文模拟预测试卷含解析
- 广东省惠州市2025-2026学年初中九年级学业质量检测数学(无答案)
- 2026草原资源保护课件
- 2026年北京市海淀区高三一模生物试卷(含答案)
- 2026年高考英语作文高分全景备考体系:模板 + 万能句型 + 实战指南
- 华勤技术2026校园招聘在线测评
- 成都城投集团笔试内容
- 电钳工岗位安全生产职责培训课件
- 2026及未来5年中国漆器工艺品制造行业市场行情动态及投资前景分析报告
- 2026年贵州综合评标专家库评标专家考试经典试题及答案
- 第8单元 单元教学设计 2026统编版二年级语文下册
- 2026年高考生物一轮复习:选择性必修3生物技术与工程 知识点考点背诵提纲
评论
0/150
提交评论