实验四_队列综合应用_实验报告

实验四_队列综合应用_实验报告

ID:15563121

大小:279.42 KB

页数:41页

时间:2018-08-04

实验四_队列综合应用_实验报告_第1页
实验四_队列综合应用_实验报告_第2页
实验四_队列综合应用_实验报告_第3页
实验四_队列综合应用_实验报告_第4页
实验四_队列综合应用_实验报告_第5页
资源描述:

《实验四_队列综合应用_实验报告》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、队列综合操作(机场起降模拟程序)实验报告一、实验内容和目的1.队列的基本概念和基本操作:队列的入队操作,队列的出队操作,判断队列是否为空队列,队列的初始化操作2.链表的基本概念和基本操作:链表的初始化,链表的定位操作,链表的插入,删除操作。二、实验原理1.队列是只允许在表的一端进行插入(队尾),而在另一端(队头)进行删除操作的线性表。队列的修改是按照先进先出的原则进行的。2.模拟程序采用两个队列结构,分别表示机场的进场队列(包括正在降落的飞机和等待降落的飞机)和出场队列(包括正在起飞的飞机和等待起飞的飞机),另外,还采用了两个链表分别储存已经降落

2、但尚未到达离场时间的飞机(即空闲状态的飞机)以及尚未到达降落时间的飞机。3.模拟程序中,飞机的数据包括航班名,飞机状态,飞机在该状态下持续的时间(用于判断飞机的起飞和降落等过程的完成情况),飞机降落的时间和日期。另外,程序中使用了全局变量记录模拟程序中的时间,并且模拟程序时间的起始值记录在数据文件中。三、程序流程图3.1程序整体流程图3.2程序主逻辑函数(控制飞机走向的函数)一、实验结果4.1程序第一次运行(或者存放飞机信息的数据文件不存在时,询问如何产生飞机信息)4.2选择手动输入飞机数据(除了输入飞机信息以外,还需要输入模拟程序的起始时间)4

3、.3选择随机生成数据4.4模拟程序开始界面从左到右,分别是进场队列,机场的机库以及出场队列。航班名前面方括号中的为飞机的状态。进场队列中的“等待”表示飞机正处于申请立场的状态,出场队列中的“等待”表示飞机正处于申请离场的状态。4.5使用pinfo参数启动程序,重新输入飞机数据(旧的数据文件会被覆盖)4.6使用apinfo参数启动程序,重新生成飞机数据(旧的数据文件被覆盖)4.7模拟程序结束,输出提示信息一、操作说明1.在第一次启动程序或者程序找不到飞机数据文件时,程序会进入到编辑飞机信息的界面。(图4.1)。然后选择由程序随机产生数据或者手动输入

4、数据。在输入数据过程中,除了飞机信息以外,还需要输入一些额外的信息。例如,模拟程序的起始时间,飞机的数量。2.程序顺利把飞机数据从数据文件读入内存以后,程序会自动进入模拟的过程。如果数据文件是由程序自动生成的,并不能保证生成的每台飞机的降落时间是均匀分布的,有可能会出现在相当长的一段时间都没有飞机信息的出现。3.当模拟结束时,并不会立即输出模拟结束的提示信息,在此过程中,跑道状态处会提示模拟程序已经结束。模拟程序结束的10秒才输出模拟程序结束的信息。二、附录:代码#include#include#includ

5、e#include#include#defineTRUE1#defineFALSE0#defineROAD_STATUS_IDLE0//表明跑道正处于空闲状态#defineROAD_STATUS_UP1//表明跑道上正有飞机在起飞#defineROAD_STATUS_DOWN2//表明跑道上正有飞机在降落#definePLANE_STATUS_IDLE0//飞机正处于空闲状态#definePLANE_STATUS_TAKE_OFF1//表示飞机称出于起飞状态#definePLANE_STA

6、TUS_LANDING2//表示飞机正处于降落状态#definePLANE_STATUS_WAIT_FOR_IN3//表示飞机正处于申请进场状态#definePLANE_STATUS_WAIT_FOR_OUT4//表示飞机正处于申请离场状态#defineQUEUE_OK1//表示队列操作成功#defineQUEUE_MALLOC_FAIL-1//表示进行队列操作时分配空间发生错误#defineQUEUE_EMPTY-2//表示对空队进行操作(插入除外)的错误信息#defineQUEUE_TRAVERSE_FAIL-3//表示遍历过程中由遍历函数引

7、起的函数终止#defineQUEUE_INDEX_OUT_OF_RANGE-4//表示进行队列操作的索引超出有效范围#defineQUEUE_NULL_POINTER-5//表示使用空指针接收内容的错误#defineLIST_OK0//表示链表操作成功#defineLIST_MALLOC_FAIL-1//表示链表操作时分配空间发生错误#defineLIST_EMPTY_LIST-2//表示对空链表进行操作(插入除外)的错误信息#defineLIST_INDEX_OUT_OF_RANGE-3//表示指定的删除和插入位置无效#defineLIST_T

8、RAVERSE_FAIL-4//表示遍历过程中由遍历函数引起的函数终止#defineFILE_OK0//表示进行文件操作成功#defin

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

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

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