数据结构-实验-队列的基本操作(共9页).doc
《数据结构-实验-队列的基本操作(共9页).doc》由会员分享,可在线阅读,更多相关《数据结构-实验-队列的基本操作(共9页).doc(9页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
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#includetypedef struct queue /* 定义队列结构 */int data; /* 队列元素类型为int */struct queue *link;QUEU
4、E;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;/* 队尾指向新入队单元 */ int DeQueue( QUEUE *head, QUEUE *tail, int *
5、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( %d , head-data );head = head-link;
6、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 ) case 0:/* 退出 */return 0;case 1:/* 进队 */printf( 请输入进队元素: ); scanf( %d, &i ); EnQueue( &head, &tail, i );printf(
7、 队内元素为:n );OutputQueue( 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 )/* 进队
8、操作, 返回1:队满 */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
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 实验 队列 基本 操作
限制150内