收藏 分销(赏)

C语言课程设计报告电子投票系统.doc

上传人:精*** 文档编号:3584856 上传时间:2024-07-10 格式:DOC 页数:19 大小:894.50KB
下载 相关 举报
C语言课程设计报告电子投票系统.doc_第1页
第1页 / 共19页
C语言课程设计报告电子投票系统.doc_第2页
第2页 / 共19页
点击查看更多>>
资源描述
C语言课程设计报告 电子投票系统 学 院 计算机学院 专 业 年 级 姓 名 学 号 教 师 年 月 日 广东工业大学计算机学院制 一.设计题目 电子投票系统 二.课程设计目的   了解软件工程中的一些系统分析,模块分析,代码设计的概念,利用WIN-TC实现学生成绩管理系统的录入、查询、删除、统计等基本操作,使用单链表结构实现学生成绩管理,了解数据库管理的基本功能,掌握C语言中的结构体、指针、函数(系统函数、自定义函数)、文件操作等知识。通过对系统的分析和设计,进一步巩固C语言的学习,以提高对开发环境的进一步认识和综合编程能力。 三. 系统功能 本系统程序功能: (1)投票者功能 a.浏览所有候选人资料 b.查询要了解的候选人的信息 c.在了解候选人之后进行投票 (2)管理员功能 a.创建新的候选人资料 b.创建新的用户资料 c.查询要了解的候选人资料 d.浏览所有的候选人资料 e.对候选人票数进行统计并排序 四.系统功能模块结构图 本程序利用单链表存储结构完成对学生成绩的动态管理,其基本功能模块如下图所示: 电子投票系统 验证账号密码 投票人 管理员 浏览候选人 浏览候选人 添加投票人 查找候选人 添加候选人 查找候选人 查看投票结果 投票    图1 程序功能模块结构图 五.程序设计及各模块函数功能简述 1.数据结构 链表是线形表的一种,线形表分为顺序存储结构和链式存储结构。线形表的顺序存储结构的特点是逻辑关系上相邻的两个元素物理位置上也相邻,因此可以随机存取表中任一元素。链式存储结构的特点是用一组任意的存储单元存储线形表的数据元素。链表的最大的优点是对表的添加、删除、查找、排序等操作比较方便,因此采用链表来存储候选人,投票人相关信息。且对结点的定义如下: ttypedef struct candidate//候选人数据结构体 { long number;//候选人编号 char name[20];//候选人姓名 char intro[400];//候选人简介 int vote;//候选人得票数 }candidate; typedef struct user//投票者数据结构体 { char name[20];//投票者姓名 char ps[8];//对应密码 int power;//权限 }user; 2.main()主函数 主函数是程序入口,采用模块化设计。创建用户文档,进行账号密码验证并根据账户不同调用不同函数进入不同的界面,执行不同的功能 3.main_a()管理员界面 根据输入数字的不同调用不同的函数进入对应的功能,返回主函数。相关的一些函数如下: addcandidate(); // 创建候选人 addUser();//创建投票者 search(); //查询候选人信息 scan();//浏览候选人信息 sort();//整理所有投票 对菜单选项的选择是输入对应数字按回车键进行选择。 4.main_v(); 投票者者界面 根据输入数字的不同调用不同的函数进入对应的功能,返回主函数。相关的一些函数如下: search(); //查询候选人信息 scan();//浏览候选人信息 vote(); //投票者投票 对菜单选项的选择是输入对应数字按回车键进行选择。 5.addcandidate(); 创建候选人 当用户选择该项对应数字后,进入该函数。创建候选人文档,输入候选人信息。用for语句和if语句检查编号、姓名是否重复。在确认不再创建新候选人信息后输出所有候选人信息。 6.addUser()创建用户 当用户选择该项对应数字后,进入该函数。创建用户文档,输入用户账号与密码。用for语句和if语句检查账号名是否重复。在确认不再创建新用户信息后输出所有用户信息。 7.read()读取候选人信息 打开候选人文档,提取文档内内容 8.scan()浏览候选人信息 先调用read()读取候选人信息,利用for语句输出。 9.search() 查询候选人信息 先调用read()读取候选人信息,利用for语句查找与输入编号一致的候选人信息并输出,若查无此编号则输出“对不起,没有您要查询的候选人”。 10. sort()整理所有投票 先调用read()读取候选人信息,利用for语句,使用选择法对投票数进行排序,并输出。 11. vote()投票者投票 先调用read()读取候选人信息,输入候选人相应编号,利用for语句,将对应候选人的投票数+1,并返回到文档中,输出投票结果。若查无此编号,输出“投票失败!您要投票的号码不存在”。 六.结果 初始界面 分别输入1,1进入管理员界面 创建新候选人 输出候选人信息 投票者界面 投票以及投票结果 候选人票数排序结果 七.心得体会 在本次课程设计中,先使用结构化分析方法对系统进行分析,将整个系统细分为几个模块,再针对每个小模块编写代码。通过本次课程设计的学习以及老师的指导,学会了很多东西,了解了开发一个系统的一些步骤。尽管大部分都参考权威书籍的代码,但是在编写代码过程中还是加深了对链表的了解程度。开发工具用的是vc++6.0。这个程序还存在很多需要改进的地方,如密码输入后直接显示了出来,而不是*,缺少安全性;每个投票人不仅仅只能投一票等等。但我会继续努力学习,争取写出更好的程序 源代码 #include<stdio.h> #include<string.h> #include<stdlib.h> #include<conio.h> #define closegr closegraph #define N 30 void 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 candidate//候选人数据结构体 { long number;//候选人编号 char name[20];//候选人姓名 char intro[400];//候选人简介 int vote;//候选人得票数 }candidate; typedef struct user//投票者数据结构体 { char name[20];//投票者姓名 char ps[8];//对应密码 int power;//权限 }user; candidate c_man[N]; user total_user[N]; void main_v()//投票者者界面 { int key; do { printf("*************************************************************\n"); printf("********************欢迎进入投票员界面***********************\n"); printf("*************************************************************\n"); printf("** 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 DataFile[20]="候选人.txt",next;// DataFile存储候选人信息的文件名,next为是否进行下一次投标操作的选项 candidate TempS; FILE *fp; begin: flag=0;//flag用来标志是否找对应编号,即投票是否成功 read(); printf("请输入您要投票的候选人的号码:"); scanf("%ld",&candidatenum); printf("您所投票的候选人号码是:%ld\n",candidatenum); for(i=0;i<c_total;i++) { if(c_man[i].number==candidatenum) { flag=1; c_man[i].vote++; } } if(flag) { printf("投票成功\n"); fp=fopen(DataFile,"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;i<c_total;i++) { fwrite(&c_man[i],sizeof(candidate),1,fp); } fclose(fp); } else { printf("投票失败!您要投票的号码不存在\n"); printf("按任意键返回首页! \n"); getch(); return; } fp=fopen(DataFile,"rb");// 显示投票后的情况 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.vote); } 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); switch(key) { case 1:addcandidate();break; case 2:addUser();break; case 3:search();break; case 4:scan();break; case 5:sort(); break; case 0:break; default:break; } }while(key!=0); } void addcandidate()//创建候选人 { char DataFile[20]="候选人.txt"; FILE * fp=NULL; char c; int over_flag=0; candidate TempS; read(); fp=fopen(DataFile,"ab+"); do { printf(" *****************创建新候选人*****************\n"); printf("请输入:"); printf("候选人号码:");scanf("%ld",&TempS.number); for(i=0;i<c_total;i++)//检查输入编号是否有重复 { if(TempS.number==c_man[i].number) { printf("该号码已存在.按任意键浏览所有候选人..."); getch(); over_flag=1; break; } } if (over_flag) { over_flag=0; continue; } printf(" 姓名:");scanf("%s",&TempS.name); TempS.name[19]='\0'; for(i=0;i<c_total;i++) { if(strcmp(TempS.name,c_man[i].name)==0) { printf("该姓名已存在!请再输入一次!按任意键继续..."); getch(); over_flag=1; break; } } if (over_flag) { over_flag=0; continue; } printf(" 简介:"); fflush(stdin); gets(TempS.intro); TempS.intro[399]='\0'; TempS.vote=0; c_man[c_total]=TempS;//将数据加入原始数据,用于下一次输入比较 c_total++; if(fwrite(&TempS,sizeof(candidate),1,fp)!=1) { printf("\nwrite file is fail! End with any key\n",DataFile); perror("write file fail"); getch(); exit(1); } printf("要继续创建新的候选人吗?是(Y)/否(N): "); fflush(stdin); c=getchar(); }while(c=='Y'||c=='y'); fclose(fp); printf("候选人资料:\n"); // 在屏幕上显示文件内容 printf("*****************************************************************"); fp=fopen(DataFile,"rb"); if(fp==NULL) { printf("\nOpen file %s fail! 任意键结束 \n",DataFile); perror("Open file fail"); getch(); exit(1); } while(fread(&TempS,sizeof(candidate),1,fp)!=(int)NULL) { printf("\n号码:%-15ld姓名:%-15s简介:%s",TempS.number,TempS.name,TempS.intro); } fclose(fp); printf("\n*****************************************************************"); printf("\n按任意键返回首页!"); getch(); } void read()//读取候选人信息 { char DataFile[20]="候选人.txt"; FILE * fp=NULL; c_total=0; fp=fopen(DataFile,"rb"); if(fp==NULL) { printf("\nOpen file %s fail! 任意键结束 \n",DataFile); perror("Open file fail"); getch(); exit(1); } while(fread(&c_man[c_total],sizeof(candidate),1,fp)!=(int)NULL) { c_total++; } fclose(fp); } void addUser()//创建用户 { FILE *fp=NULL; char DataFile[20]="用户.txt";//存储投票人信息的文件名 user TempS; int over_flag=0; char c; fp=fopen(DataFile,"rb");//读入原始数据,用于检查输入是否有重复 if(fp==NULL) { printf("\nOpen file %s fail! 任意键结束 \n",DataFile); perror("Open file fail"); getch(); exit(1); } while(fread(&total_user[total],sizeof(user),1,fp)!=(int)NULL) { total++; } fclose(fp); fp=fopen(DataFile,"ab+"); do { printf(" *****************创建新用户***************** "); printf("请输入:"); printf("用户名:");scanf("%s",&TempS.name); TempS.name[19]='\0'; for(i=0;i<total;i++)//检查输入姓名是否有重复 { if(strcmp(TempS.name,total_user[i].name)==0) { printf("该用户名已存在!按任意键浏览所有用户..."); getch(); over_flag=1; break; } } if (over_flag) { over_flag=0; continue; } printf(" 密码:"); scanf("%s",&TempS.ps); TempS.ps[7]='\0'; printf(" 权限:");scanf("%d",&TempS.power); if(TempS.power!=1) { TempS.power=0; } total_user[total]=TempS;//将数据加入原始数据 total++; if(fwrite(&TempS,sizeof(user),1,fp)!=1) { printf("\nwrite file is fail! 任意键结束\n",DataFile); perror("write file fail"); getch(); exit(1); } printf("要继续创建新用户吗?是(Y)/否(N):"); getchar(); c=getchar(); }while(c=='Y'||c=='y'); fclose(fp); printf("用户资料数据处理完毕.\n",DataFile);//在屏幕上显示文件内容 printf("所有用户具体情况如下:\n"); fp=fopen(DataFile,"rb"); printf("************************************************************"); if(fp==NULL) { printf("\nOpen file is fail! End With any key \n",DataFile); perror("Open file fail"); getch(); exit(1); } printf("\n姓名\t\t密码\t\t权限\n"); while(fread(&TempS,sizeof(user),1,fp)!=(int)NULL) { printf("\n%s\t\t%-8s\t\t%d\n",TempS.name,TempS.ps,TempS.power); } fclose(fp); printf("************************************************************"); printf("\n按任意键返回首页!"); getch(); } void scan()//浏览候选人信息 { read(); printf("候选人资料:\n"); printf("***************************************************************\n"); for(i=0;i<c_total;i++) { printf("号码:%-15ld",c_man[i].number); printf("姓名:%-19s",c_man[i].name); printf("简介:%s\n",c_man[i].intro); } printf("***************************************************************"); printf("\n按任意键返回首页!"); getch(); } void search() //查询候选人信息 { char c; long number; int flag=0; read(); do { printf("\n\t请输入要查询的候选人号码:"); scanf("%ld",&number); for(i=0;i<c_total;i++) { if(number==c_man[i].number) { printf("\t您要查询的候选人信息如下:\n\n"); printf("\t号码:%ld \n",c_man[i].number); printf("\t姓名:%s \n",c_man[i].name); printf("\t简介:%s \n",c_man[i].intro); flag=1; break; } } if (flag) { flag=0; } else { printf("\t对不起,没有您要查询的候选人\n"); } printf("\t要继续查询候选人吗?是(Y)/否(N): "); getchar(); c=getchar(); }while((c=='Y')||(c=='y')); } void sort()//整理所有投票 { int i,k,j; candidate c_man2[N]/*存放排序后的数据 */, temp; read(); for(i=0;i<c_total;i++) c_man2[i]=c_man[i]; for(i=0;i<c_total-1;i++)//用选择法排序 { k=i; for(j=i+1;j<c_total;j++) { if(c_man2[k].vote<c_man2[j].vote)k=j; } if(k!=i){ temp=c_man2[i];c_man2[i]=c_man2[k];c_man2[k]=temp; } } //排序结束 printf("票数从高到低排列如下:\n"); printf("***********************************************\n"); printf("*号码 候选人 票数 *\n"); printf("***********************************************\n"); for(i=0;i<c_total;i++) //输出排序后的结果 { printf("* %-13ld %-13s %-6d *\n",c_man2[i].number,c_man2[i].name,c_man2[i].vote); } printf("***********************************************\n"); printf("按任意键返回首页!"); fflush(stdin); getch(); } void main() { FILE * fp=NULL; char DataFile[20]="用户.txt"; char relogin;//是否重新登录的标志 int success=0; user input_user,temp_user; printf("管理员账号密码都为1\n"); printf("\n"); printf("*************************************************************\n"); printf("********************欢迎登录电子投票系统*********************\n"); printf("*************************************************************\n"); printf("* *\n"); again: printf("* 请输入用户名: *"); scanf("%s",input_user.name); printf("* 请输入密码: *"); scanf("%s",input_user.ps); printf("*************************************************************\n"); fflush(stdin); fp=fopen(DataFile,"ab"); if(fp==NULL) { printf("\nOpen file %s fail! 按任意键结束\n",DataFile); perror("Open file fail"); getch(); exit(1); } if(strcmp(input_user.name,"1")==0 && (strcmp(input_user.ps,"1")==0))//校验用户名和密码,若用户名和密码分别为1,是管理员,
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传
相似文档                                   自信AI助手自信AI助手

当前位置:首页 > 学术论文 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服