数据结构实验报告(一):实现队列和栈的各种算法及操作.doc

数据结构实验报告(一):实现队列和栈的各种算法及操作.doc

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构实验报告(一):实现队列和栈的各种算法及操作

佛山科学技术学院  实 验 报 告  课程名称 数据结构    实验项目 实现队列和栈的各种算法及操作    专业班级 10网络工程2 姓 名 张珂卿 学 号 2010394212   指导教师 成 绩 日 期 2011年11月9日     一、目的和要求  1. 理解队列和栈的顺序存储结构和链式存储结构。通过本实验,熟悉队列、栈的结构特点;  2. 熟悉队列、栈结构上的操作与算法的实现。    ?  二、实验内容   1. 队列的基本操作和应用;   2. 栈的基本操作和应用。   ?    三、仪器、设备和材料  1. 适合实验要求的计算机系统;   2. C语言编程平台。    ?  四、实验原理与实验代码  队列与栈是一种操作受限制的线性表,在了解线性表的基本原理的基础上,理解与完成此项实验。   #include stdio.h  #include windows.h  #include malloc.h    #define MAXSIZE 50      typedef struct QNode{  char data; //数组元素的存储结构  }QNode,*QLink;         typedef struct Queue{  QNode* front;   QNode* rear;  int size;   }*QueueArray;      /****************************    初始化队列数组   分配存储空间   初始化队头与队尾  ****************************/    int InitQueue(QueueArray queue)   {    QLink ql;    printf(\n初始化队列:);  ql= (QNode*)malloc(MAXSIZE*sizeof(QNode)); //分配存储空间  if(!ql)     {    printf(MEMERY ERROR!);   return 0;   }    queue-front = queue-rear = ql; //初始化队头指针与队尾指针  queue-size = 0;   return 1;  }  /*********************************    入队操作  队满条件:queue-size+1 == MAXSIZE   *********************************/    int EnQueue(QueueArray queue)   {   if((queue-size+1)MAXSIZE) //是否队满    {  printf(已经超出了预设最大队列长度%d!,MAXSIZE);   return 0;  }   fflush(stdin); //清理标准输入流    printf(请输入入队元素:);  scanf(%c,queue-rear-data);   queue-rear = (queue-rear)++; //队尾元素移动    queue-size++; //队长度增加    return 1;    }    /******************************   出队操作    队空条件:queue-size == 0    ******************************/   int DeQueue(QueueArray queue)   {   if(0 == queue-size) //是否队空    {    printf(注意:队列已经为空!\n);   return 0;   }  printf(队头元素为:%c\n,queue-front-data);  (queue-front)++; //队头元素移动    queue-size--; //队长度减少   return 1;  }  void main()    {  QueueArray queue = (QueueArray)malloc(sizeof(QueueArray));  int choose;    InitQueue(queue);    while(1){    printf(\n请选择操作:1.入队\t2

文档评论(0)

beoes + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档