数据结构-实验-队列的基本操作_第1页
数据结构-实验-队列的基本操作_第2页
数据结构-实验-队列的基本操作_第3页
数据结构-实验-队列的基本操作_第4页
数据结构-实验-队列的基本操作_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、 数据结构 实验报告实验名称:实验五 队列的基本操作一、实验目的:1、 掌握链接存储队列的进队和出队等基本操作2、 掌握环行队列的进队和出队等基本操作3、 加深对队列结构的理解,逐步培养解决实际问题的编程能力二、实验环境:计算机,同学,vc+三、实验内容和要求:(一)基础题1、编写链接队列的基本操作函数() EnQueue( QUEUE *head, QUEUE *tail, int x )进队操作 () DeQueue( QUEUE *head, QUEUE *tail, int *cp )出队操作() OutputQueue( QUEUE *head )输出队列中元素 2、调用上述函数实现

2、下列操作,操作步骤如下:(1)调用进队函数建立一个队列;(2)读取队列的第一个元素;(3)从队列中删除元素;(4)输出队列中所有元素。注:每完成一个步骤,必须及时输出队列中元素,便于观察操作结果。3、编写环型队列的基本操作函数() EnQueue( int *queue, int maxn, int *head, int *tail, int x ) 进队操作, 返回1:队满 () DeQueue( int *queue, int maxn, int *head, int *tail, int *cp ) 出队操作 返回1:队空 () OutputQueue( int *queue, int

3、maxn, int h, int t )输出队列中元素 4、调用上述函数实现下列操作,操作步骤如下:(1) 调用进队函数建立一个队列;(2)读取队列的第一个元素;(3)从队列中删除元素;(4) 输出队列中所有元素。四、实验步骤:从网上把word 下载下来,认真的看题目,思考和同学讨论在老师的帮助下,完成了题目。五、实验结果与分析(含程序、数据记录及分析和实验总结等):基础题一#include#includetypedef struct queue /* 定义队列结构 */int data; /* 队列元素类型为int */struct queue *link;QUEUE;void EnQueu

4、e( QUEUE *head, QUEUE *tail, int x )/* 进队操作 */QUEUE *p;p = (QUEUE *)malloc( sizeof(QUEUE) ); p-data = x;p-link = NULL;/* 队尾指向空 */if( *head = NULL )/* 队首为空,即为空队列 */ *head = *tail = p;else (*tail)-link = p;/* 新单元进队列尾 */*tail = p;/* 队尾指向新入队单元 */ int DeQueue( QUEUE *head, QUEUE *tail, int *cp )/* 出队操作 1

5、:对空 */QUEUE *p; p = *head;if( *head = NULL )/* 队空 */return 1;*cp = (*head)-data;*head =(*head)-link;if( *head = NULL ) /* 队首为空,队尾也为空 */*tail = NULL;free( p );/* 释放单元 */ return 0;void OutputQueue( QUEUE *head )/* 输出队列中元素 */while (head != NULL ) printf( %d , head-data );head = head-link; printf( n );v

6、oid main()QUEUE *head, *tail;int op, i;head = tail = NULL; /* 将队列头和尾置为空 */ while( 1 )printf( 请选择操作,1:进队 2:出队 0:退出 );fflush( stdin );/* 清空标准输入缓冲区 */scanf( %d, &op );switch( op ) case 0:/* 退出 */return 0;case 1:/* 进队 */printf( 请输入进队元素: ); scanf( %d, &i ); EnQueue( &head, &tail, i );printf( 队内元素为:n );Ou

7、tputQueue( head );break;case 2:/* 出队 */if(DeQueue( &head, &tail, &i )= 0 ) /* 出队成功 */printf( 出队元素为: %d , 队内元素为:n , i );OutputQueue( head );elseprintf( 队空n );break;基础题 二#include#include#define MAXN 11/* 定义环行顺序队列的存储长度 */int EnQueue( int *queue, int maxn, int *head, int *tail, int x )/* 进队操作, 返回1:队满 */

8、if( *tail + 1 ) % maxn= *head )/* 队尾指针赶上队首指针, 队满 */return 1; *tail =( *tail + 1 ) % maxn ;/* 队尾指针+1 */queue*tail = x;/* 元素入对尾 */ return 0;int DeQueue( int *queue, int maxn, int *head, int *tail, int *cp )/* 出队操作 返回1:队空 */if( *head = *tail )/* 队首=队尾, 表明队列为空 */return 1;*head = ( *head + 1 ) % maxn;/*

9、队首指针+1 */ *cp = queue*head;/* 取出队首元素 */ return 0;void OutputQueue( int *queue, int maxn, int h, int t )/* 输出队列中元素 */while(h != t ) /* */h = ( h + 1 ) % maxn;printf( %d , queueh ); printf( n );void main()int qMAXN;/* 假设环行队列的元素类型为int */int q_h=0, q_t=0;/* 初始化队首,队尾指针为0 */ int op, i; while( 1 )printf( 请

10、选择操作,1:进队 2:出队 0:退出 );fflush( stdin );/* 清空标准输入缓冲区 */scanf( %d, &op );switch( op ) case 0:/* 退出 */return 0;case 1:/* 进队 */printf( 请输入进队元素: ); scanf( %d, &i );if(EnQueue( q, MAXN, &q_h, &q_t, i )!= 0 )printf( 队列满n ); else printf( 入队成功, 队内元素为:n );OutputQueue( q, MAXN, q_h, q_t ); break;case 2:/* 出队 */

11、if(DeQueue( q, MAXN, &q_h, &q_t, &i )= 0 ) /* 出队成功 */printf( 出队元素为: %d , 队内元素为:n , i );OutputQueue( q, MAXN, q_h, q_t );elseprintf( 队空n );break;提高题一#include#include#includetypedef struct int arrive;/* 病人到达时间 */int treat;/* 病人处理时间 */PATIENT;typedef struct queue /* 定义队列结构 */PATIENT data;/* 队列元素类型为int

12、*/struct queue *link;QUEUE;void EnQueue( QUEUE *head, QUEUE *tail, PATIENT x )/* 进队操作 */QUEUE *p;p = (QUEUE *)malloc( sizeof(QUEUE) );p-data = x;p-link = NULL;/* 队尾指向空 */if( *head = NULL )/* 队首为空,即为空队列 */*head = *tail = p;else (*tail)-link = p;/* 新单元进队列尾 */*tail = p;/* 队尾指向新入队单元 */ int DeQueue( QUEU

13、E *head, QUEUE *tail, PATIENT *cp )/* 出队操作 1:对空 */QUEUE *p; p = *head;if( *head = NULL )/* 队空 */return 1;*cp = (*head)-data;*head = (*head)-link;if( *head = NULL ) /* 队首为空,队尾也为空 */*tail = NULL;free( p );/* 释放单元 */ return 0;void OutputQueue( QUEUE *head )/* 输出队列中元素 */while(head != NULL ) printf( 到达时间

14、: %d 处理时间: %dn , head-data.arrive, head-data.treat );head = head-link;void InitData( PATIENT *pa, int n )/* 生成病人到达及处理时间的随机数列 */int parr = 0;/* 前一个病人到达的时间 */ int i;for( i = 0; i 20 | n 0 ) continue; if( ( p = ( PATIENT *)malloc( n * sizeof( PATIENT ) ) ) = NULL ) printf( 内存申请错误n ); return 1; InitData

15、( p, n ); /* 生成病人到达及处理时间的随机数列 */for( i = 0;i 0)/* 病人到达时间与上次处理时间迟 */ dwait += pi.arrive - nowtime;/* 累计医生等待时间 */nowtime = pi.arrive;/* 时钟推进 */EnQueue( &head, &tail, pi+ );/* 病人入队 */DeQueue( &head, &tail, &curr );/* 出队一位病人 */ pwait += nowtime - curr.arrive;/* 累计病人等待时间 */finish = nowtime + curr.treat;/* 当前病人处理结束时间 */while( i n & pi.arrive = finish )/* 下一位病人到达时间在当前病人等待时间结束之前, 入队 */EnQueue( &head, &tail, pi+ );nowtime = finish;/*

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论