![【数据结构】B类投票选举系统_第1页](http://file3.renrendoc.com/fileroot_temp3/2022-2/8/ef23f097-4d13-4b19-a949-28b1176da1df/ef23f097-4d13-4b19-a949-28b1176da1df1.gif)
![【数据结构】B类投票选举系统_第2页](http://file3.renrendoc.com/fileroot_temp3/2022-2/8/ef23f097-4d13-4b19-a949-28b1176da1df/ef23f097-4d13-4b19-a949-28b1176da1df2.gif)
![【数据结构】B类投票选举系统_第3页](http://file3.renrendoc.com/fileroot_temp3/2022-2/8/ef23f097-4d13-4b19-a949-28b1176da1df/ef23f097-4d13-4b19-a949-28b1176da1df3.gif)
![【数据结构】B类投票选举系统_第4页](http://file3.renrendoc.com/fileroot_temp3/2022-2/8/ef23f097-4d13-4b19-a949-28b1176da1df/ef23f097-4d13-4b19-a949-28b1176da1df4.gif)
![【数据结构】B类投票选举系统_第5页](http://file3.renrendoc.com/fileroot_temp3/2022-2/8/ef23f097-4d13-4b19-a949-28b1176da1df/ef23f097-4d13-4b19-a949-28b1176da1df5.gif)
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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; ;(
6、2)建立一个向量保存选举人信息 vector<People>V(N); (3)建立两个队列保存选票 deque<int>D1,D2;3.3 函数原型设计 void Luru() 候选人的姓名编号录入 void Toupiao () 每个候选人的投票录入 void Jipiao(int x) 每一票的记录 void Jieguo () 投票的结果统计3.4 主算法设计 本程序通过对选票的计算,先把选票记录在一个队列中,通过选票号码与选举人号码的比对,来保存选举人的票数个数,再用一个队列保存选举人的票数,对票数进行排序,找出最大的选举票数,最后与队列中的选举人票数进行比对,
7、相等的即为优胜者。3.5 用户界面设计 主界面分别有录入选举人,选举人投票,选票人结果,退出系统四个功能,进入录入选举人窗口输入选举人姓名和编号。选举人投票窗口输入每位选举人所选人员的编号。选票人结果窗口显示超过选举人半数的优胜者,被选举人所获票数未达到半数没有优胜者。退出系统即退出本软件。4 方案设计4.1 开发环境与工具 本程序在window7下实现和运行,并使用Visual C+6.0编译的。4.2 程序设计关键技术 本程序采用了STL中的向量和度列等数据结构来编程实现的,其中关键的是对选票的统计、计算和排序,首先用队列保存选票数,来进行选举人的票数统计,再对选举人的票数进行排序、比对,
8、最后输出优胜者的姓名及票数。4.3 个人设计实现 4.3.1 张晓峰设计实现 1.定义了候选人的类,包括姓名、选票号、票数。class Peoplepublic:string name;int id;int number; ; 2.定义了向量V vector<People>V(N); 3.定义了两个队列保存选票数和排序选票数。 deque<int>D1,D2; 4.编写了处理投票统计函数,先把选票记录在一个队列中,通过选票号码与选举人号码的比对,来保存选举人的票数个数,再用一个队列保存选举人的票数,对票数进行排序,找出最大的选举票数,最后与队列中的选举人票数进行比对,相
9、等的即为优胜者。void Jieguo()/结果1system("cls");cout<<" *选举人结果*:"<<endl<<endl<<endl;int x,x1,x2,i,j,k;for(i=0;i<N;i+)Vi.number=0;for(j=0;j<N;j+)x=D1.begin()j;Jipiao(x);for(k=0;k<N;k+)D2.push_front(Vk.number);sort(D2.begin(),D2.end();x1=D2.begin()N-1;x2=D2.
10、begin()N-2;if(x1=x2)cout<<"*没有选出优胜者!"<<endl;else if(x1<(N/2)cout<<"*没有选出优胜者!"<<endl;else for(j=0;j<N;j+)if(x1=Vj.number) cout<<"*优胜者是:"<<V<<endl; cout<<"*选票数是:"<<Vj.number<<endl;system(&qu
11、ot;pause");4.3.2 曹乔家设计实现1. 候选人信息录入函数,通过for循环来进行对各个选举人的信息录入,保存在向量中。void Luru()/录入system("cls"); cout<<" *录入选举人*:"<<endl<<endl<<endl; int j; cout<<"*一共"<<N<<"位选举人!"<<endl; cout<<endl;for(j=0;j<N;j+)co
12、ut<<"*输入第"<<j+1<<"选举人姓名:"cin>>V;cout<<"*输入第"<<j+1<<"选举人号码:"cin>>Vj.id;cout<<endl;system("pause");2. 候选人投票函数,当进入函数时,通过for循环来对各个投票者投票的记录,同时保存在建立的队列中。void Toupiao()/投票 system("cls");c
13、out<<" *选举人投票*:"<<endl<<endl<<endl;int j;for(j=0;j<N;j+)cout<<"*输入第"<<j+1<<"个人的投票号码:"int x;cin>>x;D1.push_front(x);cout<<"*投票结束!"<<endl;system("pause");3. 计票函数void Jipiao(int x)/计票int j;f
14、or(j=0;j<N;j+) if(x=Vj.id)Vj.number+;4.3.3 王子骄设计实现1.主函数的编写,在主界面中输出要进行执行的命令,然后对各个函数的调用来实现整个软件运行。int main() int i;dosystem("cls");cout<<" *欢迎使用投票选举系统*"<<endl;cout<<" *1* 录入选举人:"<<endl;cout<<" *2* 选举人投票:"<<endl;cout<<&
15、quot; *3* 选票人结果:"<<endl;cout<<" *4* 退出本系统:"<<endl;cout<<"请输入:"cin>>i;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
16、 张晓峰测试 1.选举人结果5.1.2 曹乔家测试 1.选举人的录入 2.选举人进行投票5.1.3 王子骄测试 1.软件的主界面5.2 组装与系统测试 进入主界面时,选择进入各个副界面,进入录入选举人,把各个选举人的信息录入系统,然后进行对选举人的投票,然后进行对票数的统计、排序、对比来把优胜者的信息住处。操作名称操作流程操作结果和输出录入选举人按任意键进入录入选举人界面依次输入选举人姓名和编号,完成后按回车键。选举人投票进入选举人投票界面,按照提示进入一下操作依次输入每位投票人所投的投票号码,完成后按回车键。选票人结果显示本次投票最终结果。直接显示获胜者和票数5.3 系统运行 6 课题总结6
17、.1 课题评价本实验主要采用了STL中向量,队列等数据结构类型,当进入选举人窗口,对选举人的信息进行录入,保存在所建立的向量中。再进入投票窗口,对各个选举人的号码进行投票,保存在建立的第一个队列中,进入结果窗口,先调用函数把保存在队列中的票数进行统计,排序,对比来计算出优胜者,然后在窗口中输出选举人的信息,或者没有选出优胜者。本程序简单易懂,操作简单。对于界面方面,不够美观,程序也不够实用。由于本程序只做了管理方面的实现,所以在采集数据方面还需要手动输入。由于开发能力和时间所限,本程序目前还需要在一定程度上进行改进和完善,根据以后运行问题以及学习的新知识,我们可以在功能方面进一步加强。6.2
18、团队协作 在此次数据结构课程实验中。我们学会了STL中的数据结构,使我们对数据结构又有了深的理解,在中使用向量,队列等数据结构,而且不用再对向量的建立,还有对向量和队列的功能调用,在编程过程中要学会各个成员的合作,以及各个函数的组合调用,各个成员之间的团队合作,积极配合,才能更好地完成一个完整的、成功的程序。 6.3 下一步工作通过这次编程实验,我们意识到了我们的知识还远远不过,在中的中运用数据结构,学习我们其他的知识,再把其它知识一起灵活运用,熟练的掌握我们现在的知识,并为以后的学习打下坚实的基础。我们还要继续学习数据结构的其他知识,为将来的编程打下基础。6.4 个人设计小结6.4.1 张晓
19、峰设计小结在此次程序中我设计了主要算法,通过对向量,队列的的使用,我又了解了STL中的数据结构,对比C语言的数据结构,其调用起来比较简单,其数据结构的建立和使用系统化,避免了在C语言中调用出错等可能,使用起来相对简单,对以后编写大程序有很大的帮助。6.4.1 曹乔家设计小结 对于选举人的录入和投票,主要使用了向量和队列,把主要信息保存在向量和队列中,同时也对STL中的向量和队列有所了解,为我的知识面又扩大了许多,我还要继续学习数据结构的相关知识,把自己的知识学得更丰富,更牢固,为以后打下基础。6.4.1 王子骄设计小结在主界面的设计中,通过对语句的输出,把主界面做的更加简单,明了,易懂,实用。
20、同时,也学习一下中数据结构,相对起来觉得STL中数据结构更加简单,在建立实用非常简单,还可以减少错误,可以进行深一步的学习。 7 附录A 课题任务分工A-1 课题程序设计分工学号姓名程序设计函数原型、类功能说明20133999张晓峰class Peoplevoid Jieguo()vector<People>V(N); deque<int>D1,D2;定义候选人的类处理投票统计函数20133977曹乔家void Luru()void Toupiao()void Jipiao()人员录入函数投票函数计票函数20133992王子骄main()主函数A-2 课题报告分工 章节
21、内容完成人1 课题概述1.1 课题任务1.2 课题原理 1.3 相关知识张晓峰2 需求分析2.1 课题调研 2.2 用户需求分析王子骄3 方案设计3.1 总体功能设计3.2 数据结构设计3.3 函数原型设计3.4 主算法设计3.5 用户界面设计张晓峰曹乔家王子骄张晓峰曹乔家4 方案实现4.1 开发环境与工具4.2 程序设计关键技术4.3 个人设计实现(按组员分工) 4.3.1 4.3.2 4.3.3王子骄王子骄张晓峰曹乔家王子骄5 测试与调试5.1 个人测试(按组员分工)5.1.1 5.1.2 5.1.3 5.2 组装与系统测试5.3 系统运行张晓峰曹乔家王子骄张晓峰6 课题总结6.1 课题评
22、价6.2 团队协作6.3 下一步工作6.4 个人设计心得(按组员分工)6.4.1 6.4.2 6.4.3 张晓峰张晓峰曹乔家王子骄 附录B 课题设计文档(光盘)B-1课程设计报告(电子版)B-2源程序代码(*.H,*.CPP)B-3工程与可执行文件) B-4屏幕演示录像文件(可选) 附录C 用户操作手册(可选)C.1 运行环境说明C.2 操作说明B-2源程序代码#include<iostream>#include<string>#include<vector>#include<deque>#include<iterator>#incl
23、ude<algorithm>#include<functional>#define N 3using namespace std;class Peoplepublic:string name;int id;int number; ;vector<People>V(N); deque<int>D1,D2;void Luru()/录入system("cls"); cout<<" *录入选举人*:"<<endl<<endl<<endl; int j; cout<
24、;<"*一共"<<N<<"位选举人!"<<endl; cout<<endl;for(j=0;j<N;j+)cout<<"*输入第"<<j+1<<"选举人姓名:"cin>>V;cout<<"*输入第"<<j+1<<"选举人号码:"cin>>Vj.id;cout<<endl;system("p
25、ause");void Toupiao()/投票 system("cls");cout<<" *选举人投票*:"<<endl<<endl<<endl;int j;for(j=0;j<N;j+)cout<<"*输入第"<<j+1<<"个人的投票号码:"int x;cin>>x;D1.push_front(x);cout<<"*投票结束!"<<endl;system
26、("pause");void Jipiao(int x)/计票int j;for(j=0;j<N;j+) if(x=Vj.id)Vj.number+;void Jieguo()/结果system("cls");cout<<" *选举人结果*:"<<endl<<endl<<endl;int x,x1,x2,i,j,k;for(i=0;i<N;i+)Vi.number=0;for(j=0;j<N;j+)x=D1.begin()j;Jipiao(x);for(k=0;k<N;k+)D2.push_
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年度智能化设备转让合同模板(含售后服务协议)
- 2025年度建筑废弃物资源化利用工程施工合同规范文本
- 2025年提花舒棉绒项目投资可行性研究分析报告
- 高新企业认定申请书
- 中国专业劳保鞋市场运行态势及行业发展前景预测报告
- 2025年度婚恋行业资源整合服务合同
- 2025年度新型城镇化道路建设材料采购合同
- 2025年中国胱氨酸片行业市场全景调研及投资规划建议报告
- 2025年度建筑施工安全应急救援预案合同范本
- 2025年度酱香型白酒产品研发与生产合作协议
- 江苏省盐城市鹿鸣路初级中学2024-2025学年八年级上学期期末考试语文试题(含答案)
- 《反家庭暴力》课件
- 【物理】《跨学科实践:制作简易杆秤》(教学设计)-2024-2025学年人教版(2024)初中物理八年级下册
- 新苏教版一年级数学下册第六单元《简单的数量关系(一)》教案(共2课时)
- GA/T 2146-2024法庭科学涉火案件物证检验移动实验室建设通用要求
- 2024-2025学年成都市石室联中七年级上英语期末考试题(含答案)
- 社会儿童福利院项目可行性研究报告
- JBT 1306-2024 电动单梁起重机(正式版)
- 2024年辅警招聘考试试题库含完整答案(各地真题)
- GB_T 17468-2019 电力变压器选用导则(高清正版)
- QES三体系内审作业指导书(开源铭记初稿)
评论
0/150
提交评论