




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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
3、 *queue, int maxn, int h, int t )输出队列中元素 4、调用上述函数实现下列操作,操作步骤如下:(1) 调用进队函数建立一个队列;(2)读取队列的第一个元素;(3)从队列中删除元素;(4) 输出队列中所有元素。四、实验步骤:从网上把word 下载下来,认真的看题目,思考和同学讨论在老师的帮助下,完成了题目。五、实验结果与分析(含程序、数据记录及分析和实验总结等):基础题一#include<stdio.h>#include<alloc.h>typedef struct queue /* 定义队列结构 */int data; /* 队列元素类型
4、为int */struct queue *link;QUEUE;void EnQueue( 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;/* 队尾指向新入队单元 */ in
5、t DeQueue( QUEUE *head, QUEUE *tail, int *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 !=
6、NULL ) printf( "%d ", head->data );head = head->link; printf( "n" );void main()QUEUE *head, *tail;int op, i;head = tail = NULL; /* 将队列头和尾置为空 */ while( 1 )printf( "请选择操作,1:进队 2:出队 0:退出 " );fflush( stdin );/* 清空标准输入缓冲区 */scanf( "%d", &op );switch( op )
7、 case 0:/* 退出 */return 0;case 1:/* 进队 */printf( "请输入进队元素:" ); scanf( "%d", &i ); EnQueue( &head, &tail, i );printf( "队内元素为:n" );OutputQueue( head );break;case 2:/* 出队 */if(DeQueue( &head, &tail, &i )= 0 ) /* 出队成功 */printf( "出队元素为: %d , 队内元素为
8、:n" , i );OutputQueue( head );elseprintf( "队空n" );break;基础题 二#include<stdio.h>#include<alloc.h>#define MAXN 11/* 定义环行顺序队列的存储长度 */int EnQueue( int *queue, int maxn, int *head, int *tail, int x )/* 进队操作, 返回1:队满 */if( *tail + 1 ) % maxn= *head )/* 队尾指针赶上队首指针, 队满 */return 1; *
9、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;/* 队首指针+1 */ *cp = queue*head;/* 取出队首元素 */ return 0;void OutputQu
10、eue( 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( "请选择操作,1:进队 2:出队 0:退出 " );ffl
11、ush( 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" );Outp
12、utQueue( q, MAXN, q_h, q_t ); break;case 2:/* 出队 */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<stdio.h>#include<stdlib.h>#include<alloc.
13、h>typedef struct int arrive;/* 病人到达时间 */int treat;/* 病人处理时间 */PATIENT;typedef struct queue /* 定义队列结构 */PATIENT data;/* 队列元素类型为int */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;
14、/* 队尾指向空 */if( *head = NULL )/* 队首为空,即为空队列 */*head = *tail = p;else (*tail)->link = p;/* 新单元进队列尾 */*tail = p;/* 队尾指向新入队单元 */ int DeQueue( QUEUE *head, QUEUE *tail, PATIENT *cp )/* 出队操作 1:对空 */QUEUE *p; p = *head;if( *head = NULL )/* 队空 */return 1;*cp = (*head)->data;*head = (*head)->link;if
15、( *head = NULL ) /* 队首为空,队尾也为空 */*tail = NULL;free( p );/* 释放单元 */ return 0;void OutputQueue( QUEUE *head )/* 输出队列中元素 */while(head != NULL ) printf( "到达时间: %d 处理时间: %dn ", head->data.arrive, head->data.treat );head = head->link;void InitData( PATIENT *pa, int n )/* 生成病人到达及处理时间的随机数
16、列 */int parr = 0;/* 前一个病人到达的时间 */ int i;for( i = 0; i < n; i+ ) pai.arrive = parr + rand( 15 );/* 假设病人到达的时间间隔为 014 */pai.treat = rand( 9 ) + 1;/* 假设医生处理时间为 19 */parr = pai.arrive; printf( "第%d个病人到达时间为%d处理时间为%dn", i+1, parr, pai.treat ); void main()QUEUE *head, *tail; PATIENT *p, curr;/*
17、 病人到达及处理时间信息, 当前出队病人信息 */int n, i, finish;int nowtime;/* 时钟 */int dwait, pwait;/* 医生累计等待时间, 病人累计等待时间 */head = tail = NULL;/* 将队列头和尾置为空 */ while( 1 )n = 0; nowtime = dwait = pwait = 0;printf( "请输入病人总数(120),= 0:退出 " );scanf( "%d", &n );if( n = 0 )/* 退出 */return 0;if( n > 20
18、| n < 0 ) continue; if( ( p = ( PATIENT *)malloc( n * sizeof( PATIENT ) ) ) = NULL ) printf( "内存申请错误n" ); return 1; InitData( p, n ); /* 生成病人到达及处理时间的随机数列 */for( i = 0;i < n | head != NULL ; ) /* 病人到达未结束或还有等待, 处理 */if( head = NULL ) /* 等待队列为空 */if(pi.arrive - nowtime > 0)/* 病人到达时间与上次处理时间迟 */ dwait += pi.arrive - nowtime;/* 累计医生等待时间 */nowtime = pi.arrive
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年计算机系统配套用各种消耗品项目合作计划书
- 2025年未硫化复合橡胶及其制品项目建议书
- 2025年自动检票验票机合作协议书
- 小学生防性防侵害安全教育
- 2025年企业人力资源管理师之三级人力资源管理师题库练习试卷A卷附答案
- 2019-2025年监理工程师之合同管理题库检测试卷A卷附答案
- 圣诞节活动主题策划方案
- 狼图腾介绍课件
- 脱硫安全文明施工方案
- bim一级考试试题及答案
- GB/T 42910-2023无机胶粘剂高温压缩剪切强度试验方法
- 《中华民族大团结》(初中) 全册教案(共12课)
- 安徽工贸职业技术学院辅导员考试真题2022
- 浙江建设技师学院工作人员招聘考试真题2022
- 常州施工招标开标清标评标报告
- 手术通知单模板
- 盘扣式钢管脚手架验收表
- 第十五届运动会场馆医疗保障工作方案
- 生理卫生教学课件青春期男生性教育走向成熟
- 体外诊断试剂标准品、校准品、质控品
- 部编小学语文三下识字表无拼音
评论
0/150
提交评论