ImageVerifierCode 换一换
格式:DOCX , 页数:40 ,大小:248.36KB ,
资源ID:30092168      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/30092168.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据结构课程设计舞伴问题docx.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

数据结构课程设计舞伴问题docx.docx

1、数据结构课程设计舞伴问题docx分类号编号华北水利水电大学North China Institute of Water Conservancy and Hydroelectric Power课程设计题目舞伴问题院系信息工程学院专业计算机科学与技术姓名贾宁指导教师杨彬第一章需求分析 21.1问题描述 21.2基本要求 21.2.1输入及输出格式 21.2.2程序所完成的功能 2第二章概要设计 32.1数据结构 32.2程序模块 42.3模块调用及算法 5第三章详细设计 73.1操作实现 73.2算法实现 8第四章编码调试 104.1 调试环境 104.2调试方法 104.3调试项目及调试结果 1

2、04.3.1 登陆测试 104.3.2加载学生信息 114.3.3学生配对调试 124.3.4显示总配对 134.3.5查询配对 13第五章总结 15参考文献 16附录系统源代码 17第一章需求分析1.1 问题描述一班有m个女生、n个男生(m不等于n),举办一场舞会.男女生分别编号坐在舞池 两边的椅子上, 每曲开始时 , 依次从男生和女生中各出一人配对跳舞 , 本曲没成功配对 者坐着等待下一曲找舞伴,设计一个程序模拟舞伴配对过程。1.2 基本要求1.2.1 输入及输出格式输入男、女学生的姓名、性别,由程序自动为男女生编号,可以顺序编号,也可以 随机编号,输出每曲配对情况(包括男、女生的姓名、性

3、别和编号) 。原始数据和结果 数据要保存到文件中。在读入男女生信息时,可以从文件中直接读取学生的姓名和性别 信息。输出显示时显示每首歌的配对情况,包括对应配对学生的姓名、性别以及编号。可 以输出整个舞池配对过程的所有配对情况。 将输出显示的内容对应写入到指定的文件中。1.2.2 程序所完成的功能从文件或者手动输入班级的学生信息,包括姓名和性别基本信息,根据性别使男女 生分别坐在舞池两边的座位上,学生的座位编号顺序生成,且一旦编号确定,将不再发 生变化。每一首歌曲播放时,依次从男女生队列中出来学生进行配对,由于男女生人数不一 致,会使某个队列中剩下若干学生配对不成功, 配对不成功者等待下首歌时再

4、进行配对。 该首歌结束时,配对成功的学生再回到座位上。然后再依次进行配对,未成功者等待下 首歌再进行配对。配对成功时,会显示本首歌的详细配对情况,以及整个过程的配对情况,并且可以 将配对情况写入到文件。根据男女生的姓名或者某首歌曲的名字可以查询到对应的配对情况。第二章概要设计2.1 数据结构学生座位队列:ADT StuQueue数据对象:D= ai|ai ElemSet, i=1,2.n;n 0 数据关系:R= ai D , i=1,2.n voidInitQueue(StuQueue&Q)操作结果:初始化一个空的循环队列 voidEnQueue(StuQueue&Q,FinalStustu)

5、初始条件:循环队列Q已经存在,并且无信息操作结果:向Q中循环加入信息void EnQueue2(StuQueue&Q,FinalStustu) 初始条件:循环队列已存在,非首次进循环队列 操作结果:向Q中添加信息FinalStuDeQueue(StuQueue&Q)初始条件:循环队列已存在 操作结果:使队列头的元素出队列,且返回 FinalStu 类型值ADT StuQueue / 学生座位队列 音乐队列:ADTMusicList数据对象:D= ai|ai ElemSet, i=1,2.n;n 0 数据关系: R= ai D , i=1,2.n voidInitMusic(MusicList&

6、MList)操作结果:创建循环链表voidInsertMusic(MusicList&MList,char* name)初始条件:该链表已存在 操作结果:向链表中添加数据ADT MusicList ;临时队列:ADTTempQList数据对象:D= ai|ai ElemSet, i=1,2.n;n 0 数据关系:R= ai D , i=1,2.nvoid InitQList(TempQList&TQL) 操作结果:初始化临时队列voidEnTempQueue(TempQList&TQL,FinalStustu)初始条件:队列TQL已存在 操作结果:向TQL中添加信息FinalStuDeTemp

7、Queue(TempQList&TQL)初始条件:队列TQL存在 操作结果:取出队列的对头元素,返回 FinalStu 类型ADT TempQList;2.2 程序模块 本系统主要包括登陆模块、学生入座、自动配对、显示配对过程以及查询配对 信息模块。登陆:输入正确的用户名以及密码,方可进入系统,连续输入错误三次则禁止 进入系统。学生入座:以不同的方式获取学生信息后,根据学生性别依次进入两个循环队 列,并为每个学生唯一编号。自动配对:每首歌开始时,男女生依次从坐席中出来进行本首歌的配对,配对 不成功者等待下首歌继续配对, 下首歌时,上首歌未配对成功者本首歌先进行配对显示配对过程:在播放歌曲的过程

8、中,显示播放的歌曲信息,以及本首歌的配 对信息。查询配对:根据男女生的姓名查出两人的在哪一首歌进行过配对,根据歌曲名称查询出本首歌的配对信息。文件操作:将配对情况及学生的座位信息写入文件根据系统模块的划分,本系统的功能模块图如图 2-1所示图2-1功能模块2.3模块调用及算法登陆成功后进入主界面,进入主界面后,需要先运行学生入座模块,方能进行 下边的操作。学生入座后会得到相关的基本信息。之后调用配对模块函数,进行学 生的配对。学生配对成功后,才能利用显示配对过程进行显示配对的情况,后续的 查询配对模块也必须在配对成功的基础上进行。模块间的调用流程如图 2-2所示图2-2模块调用在进行配对过程中

9、用到算法,在每首歌配对时,依次从男女生队列中出来一个学 生,进入到临时队列, 从临时队列中获取配对的情况。 在本首歌结束,下首歌开始之前, 让临时队列中的男女在分别根据性别入队,依次循环,每次调用配对函数,实现学生的 循环配对。第三章详细设计3.1 操作实现本系统包含七个文件。设计分有欢迎界面,登陆系统,入队函数,配对函数, 显示函数,查询函数等。登陆界面是整个系统的入口,其主要是让合法人员进入系 统,入队函数主要让学生进入男女队列,配对函数主要是根据每首歌曲把男女生进 行配对,显示函数主要是显示男女生的配对情况,查询函数主要是根据男女生姓名 和歌曲名查找配对情况。系统首先通过程序调用 voi

10、d main() 进入欢迎界面和系统登陆界面,根据用户的帐 号和密码登陆成功后进入主菜单。根据用户的选择可分别进入: 1.学生就坐; 2.每曲配对; 3.显示结果; 4.查询配对; 5.退出。选择“ 1.学生就坐”项,会显示学生信息来源,包括“ 1.按班级获取 (推荐) ”“2.手动输入. ”两项可供选择。其中, 1 是从文件中获取学生信息, 2是用户手动输 入学生信息。选择“2. 每曲配对”项,会显示播放歌曲的类型,有“ 1.流行”“2.复古”两个音 乐风格可供选择,当用户选择其中一个风格并确定播放后,会显示出当前播放的歌 曲名字和所配对的男女生。选择“3. 显示结果”项,会有“ 1.学生座

11、位信息”和“ 2.学生配对信息”两项操 作可供选择。当选择 1,会把学生就坐后的信息显示出来,选择 2,会把每首歌学生 的配对情况显示出来。选择“4. 查询配对”项,也有两个操作可供选择,分别是“ 1.按学生姓名”“按歌 曲名”两项。选择 1,会根据用户输入的男女生姓名查看他们的配对情况,选择 2,会根据用户输入的歌曲名称显示每首歌曲学生的配对情况。选择“5. 退出”项,会出现感谢使用系统界面,并按任意键退出系统。本系统的主流程图如图 3-1 所示开始Y结束程序3-1主流程3.2算法实现定义学生结构体FinalStu,将学生的信息放到本结构体中,定义两个循环队列Boys 和Girls队列,分别

12、存储男女生的座位信息。定义 MusicList循环链表,用于存放音乐信 息。定义TempQueue队列,用于临时存放从男女生队列中出来的学生信息。创建一个 存放每首歌配对情况的数组stuTable,用来存放播放该首歌曲时男女生的信息。每一首歌开始时,男女生依次用 Boys和Girls队列中出对,依次进入临时队列 TempQueue从TempQueue中读取男女生的信息,放到 stuTable数组中,表示该首歌的 配对情况。下首歌开始时,让临时队列中的学生再根据性别依次进入男女循环队列。同 时将存放歌曲的 MusicList 循环链表指针后移,播放下首歌曲,再执行上述操作,便可 实现循环配对。第

13、四章编码调试4.1调试环境硬件环境:In tel 1GHZ处理器(或AMD同类处理器),512 M或以上内存容量,10G 或以上硬盘容量,可连接互联网的相关设备。软件环境(软件、操作系统):Windows XP (或 Windows 2003或 Windows vista或 Win dows 7)操作系统,Microsoft Visual Studio 2008 。4.2调试方法为了提高测试效率,降低测试成本,本测试方案采用黑盒法设计基本的测试方案, 再用白盒法补充一些方案。在黑盒法测试方案中,采用等价划分技术,把所有可能的数 据划分成几个等价类。4.3调试项目及调试结果4.3.1登陆测试用户

14、根据用户名及密码登陆系统,内置用户为Admin,密码为888888。登陆成功如 图4-1所示,登陆失败如图4-2所示王界面学生耿坐 2每曲配科3蛊不结果.帕查苗配跖退岀请选择操作1-4 =图4-1登陆成功膨飜龜舖莞再见图4-2登陆失败4.3.2加载学生信息可以从文件或者手动输入学生信息,从文件中选择时,可以选择不同的文件,其运行结果如图4-2及图4-3所示图4-3选择信息来源图4-4显示获取信息433学生配对调试在进行配对之前,需要先将音乐信息加载到系统中,其加载过程如图 4-5所示请选择要放入的光盘类型*I 流行2 复古请先放入歌曲光盘-4曲光盘己就位是否现在播放炸ZH7图4-5加载音乐学生

15、就位及音乐加载成功后,开始播放音乐,并进行配对,其音乐播放情况及每首歌曲的配对情况如图4-6、图4-7及图4-8所示1 正在播放二gl 性别 序号 i贾 男 1005 菱图4-6配对开始图4-7播放下一首小小 男 1098 W吻别 L正在播放二 本苜歌的配对情况: 姓居 框别 序号 龙 /卜h 男 1008 脅 聘讯 男 1009 g 拖卷彳丁忑二首酸曲 按g停止播躺宗图4-8循环配对4.3.4显示总配对在整个过程结束后,停止播放音乐,可以显示整个过程的配对情况,其结果如图4-9所示霹馨麟豎学生配对信息图4-9显示配对结果4.3.5查询配对可以根据男女生的姓名查询两人的配对情况,当输入两个学生

16、姓名时,显示在整个过程中的配对情况,其结果如图 4-10所示霭矍嬲方式二按歌曲名图4-10姓名查询配对根据每一首歌曲情况查询在本首歌曲中的配对情况,其结果如图 4-11所示h讯 称, 名=Edp 另姓男男查询性别10081009的学牛的配对:性别1007编号半:图4-11按歌名查找第五章总结这次的课程设计懂得了理论与实际相结合是很非常重要的,只有理论知识是远远 不够的,只有把所学的理论知识与实践相结合起来,从理论中得出结论,才能真正为, 从而提高自己的实际动手能力和独立思考的能力。在整个设计过程中,构思是很花费时 间的,在构思总体架构时,需要先将需求分析搞清楚, 需要在找到了需要解决的问题后,

17、 再想办法解决该问题。而不是在设计过程中边想边解决,需要先将所有可能的问题都考 虑到,再依次解决。在整个系统设计完成后,如果再遇到新的问题,可以对系统进行适 当的更新。调试时经常会遇到这样那样的错误,有的时候是因为一些最基本的错误,如标点 的中英错误,括号的匹配问题,数据的输入错误等。当然,也有很多地方是因为用错了 解决方法。在设计的过程中,最能体现出的缺点就是基础不扎实,本可以避免的错误却 一再出现。在实现舞池配对问题过程中,需要使学生循环配对,此程序设计的是当一个光盘 的音乐播放结束时,整个配对过程随之结束,而没有让学生再次进去坐席,导致不再从 新将学生入座,就无法实现配对。设计的是在每首

18、歌开始之前学生进入队列,可以改为 当某个学生坐席为空时,随即让学生再次进入队列,可以解决不能重复换歌曲的问题。刚开始的时候我直接在开发环境下一边看题一边写代码,瞪了半天什么也没写出 来,于是我便先开始在纸上画画写写,将事件的整个过程画下来,然后考虑怎么才能运 用代码来实现,一边思考一边写一些粗略的代码,最后从上到下执行代码看看是不是符 合题目要求。有没有什么漏洞。等这些完成以后,再在开发环境下将代码完善、编译和 调试。虽然说代码还有许多要改进的地方,有的功能还不够完善,可毕竟是自己亲自写 出来的,对于程序的条理有了一个清晰的了解,对编程也有了更加深刻的认识。参考文献1谭浩强 C程序设计(第三版

19、)M.北京:清华大学出版社,2005.21997.严蔚敏,吴伟民.数据结构(C语言版)M.北京:清华大学出版社,3陆丽娜. 软件工程. 北京:经济科学出版社, 2005.4姚诗斌.数据库系统基础 .计算机工程与应用 , 1981年第 8期附录系统源代码#include#include #include #include#include#define MAXQSIZE 20 /循环队列最大存储量 #define STU_SIZE 5 /学生人数#define SIZE 100int idCount=1OOO;全局变量控制学生id自增 int len gth;记录每首歌配对的数量 int in d

20、ex=0;记录最终配对表的下标 usingnamespacestd;/舞池就坐后的学生信息结构体struct Adminchar name15;char passWord15;Admin *next;Admin *admin; struct FinalStu char name15;char sex3;int id;FinalStu stuSTU_SIZE;Fi nalStu stuSeatSTU_SIZE用来存放入座后的学生信息FinalStu stuTableSTU_SIZE2; /用来存放没收歌曲的配对情况 /舞池座位struct StuQueueFinalStu *base;int f

21、ront;int rear;StuQueue Boys; /男生队列 StuQueue Girls; /女生队列/初始化学生坐席void InitQueue(StuQueue &Q)Q.base=(FinalStu*)malloc(MAXQSIZE* sizeof(FinalStu); if (Q.base=NULL)return ;Q.front=Q.rear=0;/学生就坐 ,首次入队,需要获取学生的 idvoid EnQueue(StuQueue &Q,FinalStu stu)int i=100;if (Q.rear+1)%MAXQSIZE=Q.front)return ;strcpy

22、(Q.baseQ.rear.name,stu.name);strcpy(Q.baseQ.rear.sex,stu.sex);Q.baseQ.rear.id=idCount+;Q.rear=(Q.rear+1)%MAXQSIZE;/非首次入队,不需获取学生的 idvoid EnQueue2(StuQueue &Q,FinalStu stu)strcpy(Q.baseQ.rear.name,stu.name);strcpy(Q.baseQ.rear.sex,stu.sex);Q.baseQ.rear.id=stu.id;Q.rear=(Q.rear+1)%MAXQSIZE;/从坐席上出来Final

23、Stu DeQueue(StuQueue &Q)FinalStu stu;if (Q.rear!=Q.front)stu=Q.baseQ.front;Q.front=(Q.front+1)%MAXQSIZE;return stu;/存放音乐信息struct Musicchar M_Name15;Music *next;/存放音乐链 ,循环链表struct MusicList Music *head;Music *tail;MusicList ML;Music *M_p; / 初始化指针 void InitMusic(MusicList & MList) MList.head=MList.tai

24、l=(Music *)malloc( sizeof(Music); MList.head-next=NULL;/向音乐链表中添加音乐void InsertMusic(MusicList &MList, char* name) Music *p=(Music*)malloc( sizeof(Music);MList.tail-next=p; strcpy(p-M_Name,name);MList.tail=p;MList.tail-next=MList.head; /临时队列,用于存放从男女生队列中配对成成功的学生信息 struct TempQueueFinalStu stu;TempQueue

25、 * next;struct TempQListTempQueue *front;TempQueue *rear;TempQList TempQL; /临时队列,用于存放每次出来的男女生信息 void InitQList(TempQList &TQL)TQL.front=TQL.rear=(TempQueue *)malloc( sizeof(TempQueue); TQL.front-next=NULL;void EnTempQueue(TempQList & TQL,FinalStu stu)TempQueue *p=(TempQueue *)malloc(sizeof(TempQueue

26、); p-stu=stu;p-next=NULL;TQL.rear-next=p;TQL.rear=p;FinalStu DeTempQueue(TempQList &TQL)FinalStu stu;TempQueue *p;p=TQL.front-next;if (p=TQL.rear) stu=p-stu; TQL.rear=TQL.front;else stu=p-stu; TQL.front-next=p-next;free(p);return stu;/= 配对信息存放 = struct MatchListchar musicName20;FinalStu stu2;MatchLi

27、st matchTableSIZE;/从键盘读入学生信息void GetInfKey()for(int i=0;iSTU_SIZE;i+)coutvv输入第i+1个学生的姓名:; scanf(%s,stui.name);coutvv输入第i+1个学生的性别:; scanf(%s,stui.sex);/学生入座void StudentSit()for(int i=0;iSTU_SIZE;i+)if(strcmp(stui.sex,男)=0)EnQueue(Boys,stui);elseEnQueue(Girls,stui);/获取就坐后的男女生性别、姓名、编号 ,stuSeat 存放就坐后的学生

28、信息,包括学生编 号void GetStuSeat()int i=0;int j=0;i=Boys.front;j=Girls.front;while(i!=Boys.rear)stuSeati=Boys.basei;i+;while(j!=Girls.rear)stuSeati=Girls.basej;j+;i+;/将就座的学生信息写入文件int InFileStuSeat()FILE *fp_Seat;int res=0;if(fp_Seat=fopen(Seat.txt,wt)=NULL)coutvv读取学生座位信息失败! !;return -1;fprin tf(fp_Seat,姓名

29、t 性别 t 序号 n);for(int i=0;iSTU_SIZE;i+)fprintf(fp_Seat,%st%st%d,stuSeati.name,stuSeati.sex,stuSeati.id);fprintf(fp_Seat,n ); res+;fclose(fp_Seat);return res;void PrintStuSeat()coutvvttt 姓名 t 性别 t 序号e ndl;for(int i=0;iSTU_SIZE;i+)coutttt stuSeati.namet; coutstuSeati.sext stuSeati.idendl; /从文件中获取管理员信息 void ReadAdmin()admi

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1