成都工业学院计算机工程系
《数据结构》·实验报告
实验名称 实验三、循环队列的应用与串的匹配操作 实验时间 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;
while (front != NULL)
{
p = front-ne
您可能关注的文档
最近下载
- 分点进水多级AO污水处理工艺设计计算探讨.pdf VIP
- 高中物理必修二圆周运动习题精选.doc VIP
- (必会)军队文职(中医学)近年考试真题题库资料汇总(含答案).pdf VIP
- 2025年安徽分类考试对口升学语文真题试卷 .pdf VIP
- (必会)军队文职(公共科目)近年考试真题题库资料汇总(含答案).pdf VIP
- 专题01-语言文字运用【真题汇编】(2021-2025)五年高考真题语文分类汇编-含答案解析.pdf VIP
- 分段进水多级 AO 工艺的特点与问题.pdf VIP
- 沉淀+多级 AO+混凝沉淀废水处理工艺.docx VIP
- 2025年新版对口高考试卷及答案安徽.doc VIP
- 不同回流比对多级AO工艺污染物去除的影响.docx VIP
原创力文档

文档评论(0)