C语言课程设计报告电子投票系统.doc
《C语言课程设计报告电子投票系统.doc》由会员分享,可在线阅读,更多相关《C语言课程设计报告电子投票系统.doc(19页珍藏版)》请在咨信网上搜索。
1、C语言课程设计报告电子投票系统学 院 计算机学院 专 业 年 级 姓 名 学 号 教 师 年 月 日广东工业大学计算机学院制一.设计题目电子投票系统二课程设计目的了解软件工程中的一些系统分析,模块分析,代码设计的概念,利用WIN-TC实现学生成绩管理系统的录入、查询、删除、统计等基本操作,使用单链表结构实现学生成绩管理,了解数据库管理的基本功能,掌握C语言中的结构体、指针、函数(系统函数、自定义函数)、文件操作等知识。通过对系统的分析和设计,进一步巩固C语言的学习,以提高对开发环境的进一步认识和综合编程能力。三 系统功能本系统程序功能:(1)投票者功能a.浏览所有候选人资料b.查询要了解的候选
2、人的信息c.在了解候选人之后进行投票(2)管理员功能a.创建新的候选人资料b.创建新的用户资料c.查询要了解的候选人资料d.浏览所有的候选人资料e.对候选人票数进行统计并排序四系统功能模块结构图本程序利用单链表存储结构完成对学生成绩的动态管理,其基本功能模块如下图所示:电子投票系统验证账号密码投票人管理员浏览候选人浏览候选人添加投票人查找候选人添加候选人查找候选人查看投票结果投票 图1程序功能模块结构图五程序设计及各模块函数功能简述1数据结构链表是线形表的一种,线形表分为顺序存储结构和链式存储结构。线形表的顺序存储结构的特点是逻辑关系上相邻的两个元素物理位置上也相邻,因此可以随机存取表中任一元
3、素。链式存储结构的特点是用一组任意的存储单元存储线形表的数据元素。链表的最大的优点是对表的添加、删除、查找、排序等操作比较方便,因此采用链表来存储候选人,投票人相关信息。且对结点的定义如下:ttypedef struct candidate/候选人数据结构体 long number;/候选人编号 char name20;/候选人姓名 char intro400;/候选人简介 int vote;/候选人得票数candidate;typedef struct user/投票者数据结构体 char name20;/投票者姓名 char ps8;/对应密码 int power;/权限user;2.ma
4、in()主函数主函数是程序入口,采用模块化设计。创建用户文档,进行账号密码验证并根据账户不同调用不同函数进入不同的界面,执行不同的功能3main_a()管理员界面根据输入数字的不同调用不同的函数进入对应的功能,返回主函数。相关的一些函数如下:addcandidate(); / 创建候选人 addUser();/创建投票者 search(); /查询候选人信息 scan();/浏览候选人信息sort();/整理所有投票对菜单选项的选择是输入对应数字按回车键进行选择。4main_v(); 投票者者界面根据输入数字的不同调用不同的函数进入对应的功能,返回主函数。相关的一些函数如下:search();
5、 /查询候选人信息scan();/浏览候选人信息vote(); /投票者投票对菜单选项的选择是输入对应数字按回车键进行选择。5addcandidate(); 创建候选人当用户选择该项对应数字后,进入该函数。创建候选人文档,输入候选人信息。用for语句和if语句检查编号、姓名是否重复。在确认不再创建新候选人信息后输出所有候选人信息。6addUser()创建用户当用户选择该项对应数字后,进入该函数。创建用户文档,输入用户账号与密码。用for语句和if语句检查账号名是否重复。在确认不再创建新用户信息后输出所有用户信息。7read()读取候选人信息打开候选人文档,提取文档内内容8scan()浏览候选人
6、信息先调用read()读取候选人信息,利用for语句输出。9search() 查询候选人信息先调用read()读取候选人信息,利用for语句查找与输入编号一致的候选人信息并输出,若查无此编号则输出“对不起,没有您要查询的候选人”。10. sort()整理所有投票先调用read()读取候选人信息,利用for语句,使用选择法对投票数进行排序,并输出。11. vote()投票者投票先调用read()读取候选人信息,输入候选人相应编号,利用for语句,将对应候选人的投票数1,并返回到文档中,输出投票结果。若查无此编号,输出“投票失败!您要投票的号码不存在”。六结果初始界面 分别输入1,1进入管理员界面
7、创建新候选人输出候选人信息投票者界面投票以及投票结果候选人票数排序结果七心得体会 在本次课程设计中,先使用结构化分析方法对系统进行分析,将整个系统细分为几个模块,再针对每个小模块编写代码。通过本次课程设计的学习以及老师的指导,学会了很多东西,了解了开发一个系统的一些步骤。尽管大部分都参考权威书籍的代码,但是在编写代码过程中还是加深了对链表的了解程度。开发工具用的是vc+6.0。这个程序还存在很多需要改进的地方,如密码输入后直接显示了出来,而不是*,缺少安全性;每个投票人不仅仅只能投一票等等。但我会继续努力学习,争取写出更好的程序源代码#include#include#include#inclu
8、de#define closegr closegraph#define N 30void main_a(); /管理员界面void main_v(); /投票者者界面void addcandidate(); / 创建候选人void addUser();/创建投票者void search(); /查询候选人信息void scan();/浏览候选人信息void vote(); /投票者投票void read();/读取候选人信息void save();/存储候选人信息void sort();/整理所有投票int total=0,c_total=0;int i=0;typedef struct ca
9、ndidate/候选人数据结构体 long number;/候选人编号 char name20;/候选人姓名 char intro400;/候选人简介 int vote;/候选人得票数candidate;typedef struct user/投票者数据结构体 char name20;/投票者姓名 char ps8;/对应密码 int power;/权限user;candidate c_manN;user total_userN;void main_v()/投票者者界面 int key;do printf(*n);printf(*欢迎进入投票员界面*n);printf(*n);printf(*
10、 1.浏览所有候选人 2.查询候选人信息 *n); printf(* 3.投票 4.退出 *n); scanf(%d,&key);switch(key) case 1:scan();break; case 2:search();break; case 3:vote();break; case 4:break; default:break; while(key!=4);void vote() /投票者投票 long candidatenum;/定义进行操作时的临时结构体变量 int i,flag; char DataFile20=候选人.txt,next;/ DataFile存储候选人信息的文件
11、名,next为是否进行下一次投标操作的选项 candidate TempS; FILE *fp;begin: flag=0;/flag用来标志是否找对应编号,即投票是否成功 read(); printf(请输入您要投票的候选人的号码:); scanf(%ld,&candidatenum); printf(您所投票的候选人号码是:%ldn,candidatenum); for(i=0;ic_total;i+) if(c_mani.number=candidatenum) flag=1; c_mani.vote+; if(flag) printf(投票成功n); fp=fopen(DataFile
12、,wb); if(fp=NULL)/如果当前文件不存在,提示打开文件失败 printf(nOpen file is fail!End with any key.n,DataFile); perror(Open file fail); getch(); exit(1); for(i=0;ic_total;i+) fwrite(&c_mani,sizeof(candidate),1,fp); fclose(fp); else printf(投票失败!您要投票的号码不存在n); printf(按任意键返回首页! n); getch(); return; fp=fopen(DataFile,rb);/
13、 显示投票后的情况 if(fp=NULL) printf(nOpen file %s fail! End With any key n,DataFile); perror(Open file fail); getch(); exit(1); printf(整理后的最新投票情况:n); printf(n候选人号码 t候选人姓名 t票数n); while(fread(&TempS,sizeof(candidate),1,fp)!=(int)NULL) if(TempS.number!=0) printf(n%ld t%s t%d n,TempS.number,TempS.name,TempS.vo
14、te); fclose(fp); printf(n继续吗?是(Y)/否(N): ); fflush(stdin); next=getchar(); putchar(n); if(next=y|next=Y)goto begin;void main_a()/管理员界面 int key;do printf(*n);printf(*欢迎进入管理员界面*n);printf(*n);printf(* 1.创建新候选人 2.创建新用户 *n); printf(* 3.查询候选人信息 4.浏览所有候选人 *n); printf(* 5.整理所有投票 0.退出 *n); scanf(%d,&key);swit
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言 课程设计 报告 电子 投票 系统
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【精***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【精***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。