【数据结构】B类投票选举系统.doc
《【数据结构】B类投票选举系统.doc》由会员分享,可在线阅读,更多相关《【数据结构】B类投票选举系统.doc(23页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、东北大学信息科学与工程学院数据结构课程设计报告题目 投票选举问题课题组长 张晓峰课题组成员 曹乔家 王子骄专业名称 计算机科学与技术班级 计1307指导教师 杨雷2015 年 1月课程设计任务书题目:投票选举问题问题描述:在一次投票选举中,要从n个候选人中选出1个优胜者。每个候选人有一张选票,只能投给一位候选者,超过半数选票的候选人为优胜者。用一个长度为n的选举向量v表示收集到的n张选票。投票选举问题要求根据选举向量v计算选举产生的优胜者。设计要求:设计算法实现投票选举问题的程序。(1)采用STL的向量等数据结构。(2)实现STL的向量类deque。(3)应用STL的向量类实现投票选举问题。指
2、导教师签字:年月日目录1 课题概述11.1 课题任务11.2 课题原理11.3 相关知识12 需求分析12.1 课题调研12.2 用户需求分析13 方案设计13.1 总体功能设计13.2 数据结构设计13.3 函数原型设计23.4 主算法设计23.5 用户界面设计24 方案实现24.1 开发环境与工具24.2 程序设计关键技术24.3 个人设计实现34.3.1 张晓峰设计实现3 4.3.2 曹乔家设计实现44.3.3 王子骄设计实现55 测试与调试65.1 个人测试65.1.1 张晓峰测试6 5.1.2 曹乔家测试65.1.3 王子骄测试75.2 组装与系统测试85.3 系统运行86 课题总结
3、116.1 课题评价116.2 团队协作116.3 团队协作116.4 个人设计小结116.4.1 张晓峰设计小结11 6.4.2 曹乔家设计小结116.3.3 王子骄设计小结117 附录A 课题任务分工12A-1 课题程序设计分工12A-2 课题报告分工13 附录B 课题设计文档(光盘)13 B-1课程设计报告(电子版)13B-2源程序代码(*.H,*.CPP)13B-3工程与可执行文件)13 B-4屏幕演示录像文件(可选)13 附录C 用户操作手册(可选)13C.1 运行环境说明13C.2 操作说明13 1 课题概述1.1 课题任务【问题描述】在一次投票选举中,要从n个候选人中选出1个优胜
4、者。每个候选人有一张选票,只能投给一位候选者,超过半数选票的候选人为优胜者。用一个长度为n的选举向量v表示收集到的n张选票。投票选举问题要求根据选举向量v计算选举产生的优胜者。【设计要求】设计算法实现投票选举问题的程序。(1)采用STL的向量等数据结构。(2)实现STL的向量类deque。(3)应用STL的向量类实现投票选举问题。1.2 课题原理 本实验采用向量来保存选举人的姓名,选举号码和选举票数,通过对票数的计算和排序,选出票数最多的人来作为优胜者。1.3 相关知识 本实验主要运用C+中STL的向量及队列deque等数据结构,运用C+中的类等相关知识。 2 需求分析2.1 课题调研 投票选
5、举采用对票数的计算来选出优胜者,通过对不记名的选票,来计算票数,投票软件运用算法对选票进行计算,直接自动生成选票结果。2.2 用户需求分析 本程序采用简单的界面,可以让使用者对如何使用一目了然,界面简单、大方。STL中的deque向量类保存投票信息,只需输入每个候选人的号码和候选人所投的号码,最终结果将自动生成,便于使用者的使用。 3 方案设计3.1 总体功能设计 本软件要实现对每个候选人的编号功能,每个候选人的投票功能,以及最终优胜候选人的输出功能。3.2 数据结构设计(1)候选人的类class Peoplepublic:string name;int id;int number; ;(2)
6、建立一个向量保存选举人信息 vectorV(N); (3)建立两个队列保存选票 dequeD1,D2;3.3 函数原型设计 void Luru() 候选人的姓名编号录入 void Toupiao () 每个候选人的投票录入 void Jipiao(int x) 每一票的记录 void Jieguo () 投票的结果统计3.4 主算法设计 本程序通过对选票的计算,先把选票记录在一个队列中,通过选票号码与选举人号码的比对,来保存选举人的票数个数,再用一个队列保存选举人的票数,对票数进行排序,找出最大的选举票数,最后与队列中的选举人票数进行比对,相等的即为优胜者。3.5 用户界面设计 主界面分别有录
7、入选举人,选举人投票,选票人结果,退出系统四个功能,进入录入选举人窗口输入选举人姓名和编号。选举人投票窗口输入每位选举人所选人员的编号。选票人结果窗口显示超过选举人半数的优胜者,被选举人所获票数未达到半数没有优胜者。退出系统即退出本软件。4 方案设计4.1 开发环境与工具 本程序在window7下实现和运行,并使用Visual C+6.0编译的。4.2 程序设计关键技术 本程序采用了STL中的向量和度列等数据结构来编程实现的,其中关键的是对选票的统计、计算和排序,首先用队列保存选票数,来进行选举人的票数统计,再对选举人的票数进行排序、比对,最后输出优胜者的姓名及票数。4.3 个人设计实现 4.
8、3.1 张晓峰设计实现 1.定义了候选人的类,包括姓名、选票号、票数。class Peoplepublic:string name;int id;int number; ; 2.定义了向量V vectorV(N); 3.定义了两个队列保存选票数和排序选票数。 dequeD1,D2; 4.编写了处理投票统计函数,先把选票记录在一个队列中,通过选票号码与选举人号码的比对,来保存选举人的票数个数,再用一个队列保存选举人的票数,对票数进行排序,找出最大的选举票数,最后与队列中的选举人票数进行比对,相等的即为优胜者。void Jieguo()/结果1system(cls);cout *选举人结果*:en
9、dlendlendl;int x,x1,x2,i,j,k;for(i=0;iN;i+)Vi.number=0;for(j=0;jN;j+)x=D1.begin()j;Jipiao(x);for(k=0;kN;k+)D2.push_front(Vk.number);sort(D2.begin(),D2.end();x1=D2.begin()N-1;x2=D2.begin()N-2;if(x1=x2)cout*没有选出优胜者!endl;else if(x1(N/2)cout*没有选出优胜者!endl;else for(j=0;jN;j+)if(x1=Vj.number) cout*优胜者是:Vj.
10、nameendl; cout*选票数是:Vj.numberendl;system(pause);4.3.2 曹乔家设计实现1. 候选人信息录入函数,通过for循环来进行对各个选举人的信息录入,保存在向量中。void Luru()/录入system(cls); cout *录入选举人*:endlendlendl; int j; cout*一共N位选举人!endl; coutendl;for(j=0;jN;j+)cout*输入第j+1Vj.name;cout*输入第j+1Vj.id;coutendl;system(pause);2. 候选人投票函数,当进入函数时,通过for循环来对各个投票者投票的
11、记录,同时保存在建立的队列中。void Toupiao()/投票 system(cls);cout *选举人投票*:endlendlendl;int j;for(j=0;jN;j+)cout*输入第j+1x;D1.push_front(x);cout*投票结束!endl;system(pause);3. 计票函数void Jipiao(int x)/计票int j;for(j=0;jN;j+) if(x=Vj.id)Vj.number+;4.3.3 王子骄设计实现1.主函数的编写,在主界面中输出要进行执行的命令,然后对各个函数的调用来实现整个软件运行。int main() int i;dosy
12、stem(cls);cout *欢迎使用投票选举系统*endl;cout *1* 录入选举人:endl;cout *2* 选举人投票:endl;cout *3* 选票人结果:endl;cout *4* 退出本系统:endl;couti;switch(i)case 1: Luru();break;case 2:Toupiao();break;case 3:Jieguo();break;case 4:break;default:cout*输入错误!,请重新输入:;while(i!=4);return 0; 5 测试与调试5.1 个人测试 5.1.1 张晓峰测试 1.选举人结果5.1.2 曹乔家测试
13、 1.选举人的录入 2.选举人进行投票5.1.3 王子骄测试 1.软件的主界面5.2 组装与系统测试 进入主界面时,选择进入各个副界面,进入录入选举人,把各个选举人的信息录入系统,然后进行对选举人的投票,然后进行对票数的统计、排序、对比来把优胜者的信息住处。操作名称操作流程操作结果和输出录入选举人按任意键进入录入选举人界面依次输入选举人姓名和编号,完成后按回车键。选举人投票进入选举人投票界面,按照提示进入一下操作依次输入每位投票人所投的投票号码,完成后按回车键。选票人结果显示本次投票最终结果。直接显示获胜者和票数5.3 系统运行 6 课题总结6.1 课题评价本实验主要采用了STL中向量,队列等
14、数据结构类型,当进入选举人窗口,对选举人的信息进行录入,保存在所建立的向量中。再进入投票窗口,对各个选举人的号码进行投票,保存在建立的第一个队列中,进入结果窗口,先调用函数把保存在队列中的票数进行统计,排序,对比来计算出优胜者,然后在窗口中输出选举人的信息,或者没有选出优胜者。本程序简单易懂,操作简单。对于界面方面,不够美观,程序也不够实用。由于本程序只做了管理方面的实现,所以在采集数据方面还需要手动输入。由于开发能力和时间所限,本程序目前还需要在一定程度上进行改进和完善,根据以后运行问题以及学习的新知识,我们可以在功能方面进一步加强。6.2 团队协作 在此次数据结构课程实验中。我们学会了ST
15、L中的数据结构,使我们对数据结构又有了深的理解,在中使用向量,队列等数据结构,而且不用再对向量的建立,还有对向量和队列的功能调用,在编程过程中要学会各个成员的合作,以及各个函数的组合调用,各个成员之间的团队合作,积极配合,才能更好地完成一个完整的、成功的程序。 6.3 下一步工作通过这次编程实验,我们意识到了我们的知识还远远不过,在中的中运用数据结构,学习我们其他的知识,再把其它知识一起灵活运用,熟练的掌握我们现在的知识,并为以后的学习打下坚实的基础。我们还要继续学习数据结构的其他知识,为将来的编程打下基础。6.4 个人设计小结6.4.1 张晓峰设计小结在此次程序中我设计了主要算法,通过对向量
16、,队列的的使用,我又了解了STL中的数据结构,对比C语言的数据结构,其调用起来比较简单,其数据结构的建立和使用系统化,避免了在C语言中调用出错等可能,使用起来相对简单,对以后编写大程序有很大的帮助。6.4.1 曹乔家设计小结 对于选举人的录入和投票,主要使用了向量和队列,把主要信息保存在向量和队列中,同时也对STL中的向量和队列有所了解,为我的知识面又扩大了许多,我还要继续学习数据结构的相关知识,把自己的知识学得更丰富,更牢固,为以后打下基础。6.4.1 王子骄设计小结在主界面的设计中,通过对语句的输出,把主界面做的更加简单,明了,易懂,实用。同时,也学习一下中数据结构,相对起来觉得STL中数
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 投票 选举 系统
限制150内