实验三栈和队列及其应用(I)

实验三栈和队列及其应用(I)

ID:47644559

大小:83.90 KB

页数:11页

时间:2019-08-26

实验三栈和队列及其应用(I)_第1页
实验三栈和队列及其应用(I)_第2页
实验三栈和队列及其应用(I)_第3页
实验三栈和队列及其应用(I)_第4页
实验三栈和队列及其应用(I)_第5页
资源描述:

《实验三栈和队列及其应用(I)》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、实验项目栈和队列及其应用(I)实验内容1.采用顺序存储结构,实现栈的存储和基木操作。栈的抽象数据类型定义参见教材第45页。栈的顺序存储结构定义参见教材第46页。2.采用顺序存储结构,实现队列的存储和基本操作队列的抽象数据类型定义参见教材第59页。队列的顺序存储结构定义参见教材笫64页。算法设计与程序实现:算法分析本次实验主函数采用顺序结构,主函数调用H己编写的头文件DataStructureLinearList,h•p的相关功能函数,完成实验要求。程序实现步骤:1、顺序栈结构的基本操作:首先初始化一个顺序栈结构,然后

2、输入需入栈的元素个数N,通过一个循环依次输入N个元素,在输入的同吋调用入栈函数,这样就完成了N个元素的入栈操作,随后调用返回栈顶元素的函数,返回栈顶元素,接着通过循环调用出栈函数完成出栈操作,最麻销毁栈结构。当然在进行入栈和出栈操作时,会使用判断栈是否为空、对栈进行遍历等操作,这样就实现了对栈的基本操作。2、栈结构的基本应用:(1)将输入的十进制数转换为二进制数。首先初始化一个栈结构,构造一个空栈,然后输入十进制数N,根据十进制转换为二进制的方法(除二取余法)通过循环判断将每次除二求模的数入栈,接着通过判断栈空条件,

3、依次将栈中的元素出栈,然后输出这样就实现了十进制对二进制的转换,当然其他进制之间的也是如此。(2)Hanoi问题的实现。其主要思想就是递归,在进行递归调用函数木身的吋候,参数的传递、变量保存以及函数返回都使用了栈结构(操作系统建立)。3、顺序队列的基本操作:首先初始化一个空的顺序结构队列,然后输入需入队列的元素个数N,通过一个循环依次输入N个元素,输入的同时调用入队列函数,完成了N个元素的入队列操作,接着调用返回队头元素的函数,返回队头元素,接着通过循环调用出队列函数完成出队列操作,最后销毁顺序队列结构,这样就实现了

4、对栈的基本操作。核心程序此程序中用到的自己编写的头文件以在下面给出,而头文件的说明则在主函数中文件包含部分的注释处,核心程序如下:1.主函数如下:^include"iostrcam"//标准输入输出流库文件^include"windows,h"//cmd窗口设置函数头文件^include"ADT.h〃〃数据结构中相关结构体类型定义及相关数据类型泄义^include^DataStructureJJnearList.h"//数据结构第二章线性表中相关函数的定义及声明usingnamespacestd;cin>>c;Pus

5、hSq(S,e);voidprint(void);intmain(void)//设迸控制台窗II的背景色和前景色〃输出当前的口期实验三:栈利队列及其应用(I)“);//systemC'title数据结构实验设置cmd窗口标题system(〃colorFl〃);system(,zdate/T");print();cout«"实验内容一:采用顺序存储结构,实现栈的存储和基木操作,z«endl;SqStackS;SElemTypee;//构造一个空栈STnitStack_Sq(S);intcount;cout«〃请输入需入

6、栈的元素个数:N=cin>>count;cout«"请输入元素:";for(inti=0;i>n;cout«〃圆盘移动步骤:“;Hanoi(n,x

7、,y,z);//销毁栈SDestoryStack_Sq(S);cout«endl;print();cout«〃实验内容二:采用顺序存储结构,实现队列的存储和基木操作〃《//将I•进制数转换为二进制数endl«”请输入圜盘个数:〃;//圆盘个数SqQueueQ;QE1emTypedata;InitQueue_Sq(Q);//构造一个空队列Qcout«〃请输入需入队列的元素个数:N=〃;cin>>count;cout«"请输入元素:";for(inti=0;i>data;EnQueue^S

8、q(Q,data);}GetHeadSq(Q,data);cout«"队首元;索:"<

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。