实验三、循环队列的应用与串的匹配操作.doc

实验三、循环队列的应用与串的匹配操作.doc

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

成都工业学院计算机工程系 《数据结构》·实验报告 实验名称 实验三、循环队列的应用与串的匹配操作 实验时间 2015.10.12 学生姓名 刘志平 班级 1405022 学号 34 指导教师 陈向华老师 批阅教师 成绩 实验目的: 1)掌握循环队列和串的基本原理 2)掌握循环队列和串的存储结构 3)掌握循环队列的入队、出队、判断队空的实现方法和串的匹配方法 4)掌握循环队列和串的基本应用和实现方法 实验设备与要求: PC机一台,安装有Windows操作系统以及VC6.0及以上版本 1)熟悉C++语言编程 2)熟练使用C++语言实现循环队列的入队、出队、判断栈空等操作,串的匹配操作 3)熟练使用循环队列的入队、出队算法,串的BF算法。 实验内容: 1、舞伴配对问题:假设在周末舞会上,男士们和女士们进入舞厅时,各自排成一队。跳舞开始时,依次从男队和女队的队头上各出一人配成舞伴。若两队初始人数不相同,则较长的那一队中未配对者,等待下一轮舞曲。现要求写一算法模拟上述舞伴配对问题。 2、用BF算法实现串S=”abbacdbaafcefg”,T=”cdbaaf”的匹配操作。 实验步骤及实验结果记录: 算法分析: 1、舞伴配对问题:假设在周末舞会上,男士们和女士们进入舞厅时,各自排成一队。跳舞开始时,依次从男队和女队的队头上各出一人配成舞伴。若两队初始人数不相同,则较长的那一队中未配对者,等待下一轮舞曲。现要求写一算法模拟上述舞伴配对问题。 2、用BF算法实现串S=”abbacdbaafcefg”,T=”cdbaaf”的匹配操作。 问题分析: 先入队的男士或女士亦先出队配成舞伴。因此该问题具体有典型的先进先出特性,可用队列作为算法的数据结构。在算法中,假设男士和女士的记录存放在一个数组中作为输入,然后依次扫描该数组的各元素,并根据性别来决定是进入男队还是女队。当这两个队列构造完成之后,依次将两队当前的队头元素出队来配成舞伴,直至某队列变空为止。此时,若某队仍有等待配对者,算法输出此队列中等待者的人数及排在队头的等待者的名字,他(或她)将是下一轮舞曲开始时第一个可获得舞伴的人。 伪代码: 输入两个队列 两个队列进行入队操作 判断队列长度 两个队列进行匹配出队操作 短队列出对完成,长队列等待下一队列的到来 设Man对为ABCDEFGH,设Woman队为IJKLMN。 当Man队列和Woman队列都入队完成之后,开始配对: I J K L M N 此时Man队列就还有两个人没有舞伴,等待下一轮Woman的队列 参照教材所列BF算法实现,串S和T的匹配操作。 (1)、在串S和串T中设比较的起始下标i和j; (2)、循环直到S中所剩字符个数小于T的长度或T的所有字符均比较完 2.1 如果S[i]=T[j],继续比较S和T的下一个字符;否则 将i和j回溯,准备下一趟比较; (3)、如果T中所有字符均比较完,则匹配成功,返回匹配的起始比较下标; 否则,匹配失败,返回0; (4)、S=”abbacdbaafcefg”,T=”cdbaaf” 程序代码1、舞伴配对问题: 头文件:LinkQueue.h #pragma once template class DataType struct Node { DataType data; Node DataType * next; }; templateclass DataType class LinkQueue { public: LinkQueue(); ~LinkQueue(); void EnQueue(DataType x); DataType DeQueue(); DataType GetQueue(); int getArrayLen(DataType Array[]); int Empty(); private: NodeDataType * front, *rear; }; 源文件:LinkQueue.cpp #includeLinkQueue.h templateclass DataType LinkQueueDataType::LinkQueue() { NodeDataType *s = NULL; s = new NodeDataType; s-next = NULL; front = rear = s; } templateclass DataType LinkQueueDataType::~LinkQueue() { NodeDataType *p = NULL;

文档评论(0)

整理王 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档