栈的实现及进制转换.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
业务1512 王俊钢实训报告(数据结构)课程项目:栈的实现及进制转换班级: 1512姓名:王俊钢指导教师:张冰日期: 2015年11月实验二栈和队列一、实验目的1、掌握栈的特点(先进后出 FILO)及基本操作,如入栈、出栈等,栈的顺序存储结构和链式存储结构,以便在实际问题背景下灵活应用。2、掌握队列的特点(先进先出 FIFO)及基本操作,如入队、出队等,队列顺序存储结构、链式存储结构和循环队列的实现,以便在实际问题背景下灵活应用。二、实验内容 1、顺序栈的实现和运算;2、栈的运用—十进制转八进制运算。三、实验要求1、学生用C++/C完成算法设计和程序设计并上机调试通过;2、撰写实验报告,提供实验测试数据和实验结果;3、分析算法,要求给出具体的算法分析结果,包括时间复杂度和空间复杂度,并简要给出算法设计小结和心得。四、实验准备1、掌握栈和队列这两种抽象数据类型的特点,并能在相应的应用任务中正确选用它们; 2、熟练掌握顺序栈和循环队列的基本操作实现算法,特别应注意栈满和栈空的条件以及它们的描述方法,循环队列中队满和队空的描述方法。 3、在学习顺序栈的基本操作实现算法时,应注意:在书上给出的结构定义是采用了一种动态管理方式(不够时,可以再分配),但在 C 语言中,用数组来存储顺序栈,是静态分配,即不能随机分配空间,这点易引起大家的误解。五、实验步骤1、编程实现顺序栈的各种基本运算,并在此基础上设计一个主程序,完成如下功能:(1)初始化顺序栈;(2)给定一个元素,将此元素压入此栈中;(3)将栈顶一个元素弹出此栈六、实验参考代码1、顺序栈的实现和运算;#include stdio.h #include stdlib.h #define OK 1 #define ERROR 0 #define OVERFLOW -2 typedefintElemType; typedefint Status; //----- 栈的顺序存储表示 ----- #define STACK_INIT_SIZE 100 // 存储空间的初始分配量#define STACKINCREMENT 10 // 存储空间的分配增量typedefstruct { ElemType *base; ElemType *top; intstacksize; } SqStack; // 构造一个空栈 S Status InitStack(SqStack S){ S.base = (ElemType *)malloc(STACK_INIT_SIZE * sizeof(ElemType)); if(!S.base) exit (OVERFLOW); S.top = S.base; S.stacksize = STACK_INIT_SIZE; return OK; } // 判栈 S 是否为空栈Status StackEmpty(SqStack S){ if (S.top==S.base) return OK; else return ERROR; } //入栈函数Status Push (SqStack S, ElemType e) { if (S.top - S.base=S.stacksize){S.base = (ElemType* )realloc(S.base,(S.stacksize + STACKINCREMENT) * sizeof(ElemType));if(!S.base) exit (OVERFLOW);//存储分配失败S.top = S.base + S.stacksize;S.stacksize += STACKINCREMENT;}*S.top++ =e;return OK;}//PushStatus Pop (SqStack S, ElemType e) { if (S.top == S.base) return ERROR; e = * -- S.top;return OK;} //输出顺序栈函数 11voidOutStack(SqStack S) { int *p; if(S.top == S.base){ printf(这是一个空栈!); } elsefor(p= S.top-1; p= S.base;p--) printf(%6d, *p); printf(\n); } //主函数void main() { SqStack s; int cord; ElemType a; printf(第一次使用必须初始化!\n); do{printf(\n 主菜单 \n); printf( 1 初始化顺序栈 ); printf( 2 插入一个元素 ); printf( 3 删除栈顶元素 ); printf( 4 结束程序运行 ); p

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档