C语言单项选择题标准化考试系统.doc_第1页
C语言单项选择题标准化考试系统.doc_第2页
C语言单项选择题标准化考试系统.doc_第3页
C语言单项选择题标准化考试系统.doc_第4页
C语言单项选择题标准化考试系统.doc_第5页
已阅读5页,还剩12页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

青岛理工大学C语言程序设计题目 C语言单项选择题标准化考试系统 指导教师: 姓名: 学号: 班级: 专业: 地点: 时间: 2013-7-1 至 2013-7-5 一、内容【设计内容】试设计一单项选择题标准化考试系统,实现试题的录入、抽取、用户的答题、系统的自动判卷等功能。【设计要求】1、用文件保存试题库。(每个试题包括题干、4个备选答案、标准答案)2、试题录入:可随时增加试题到试题库中3、试题抽取:每次从试题库中可以随机抽出N道题(N由键盘输入)4、答题:用户可实现输入自己的答案5、自动判卷:系统可根据用户答案与标准答案的对比实现判卷并给出成绩。二、上机环境操作系统:windows.XP开发工具: VC6.0 三、函数调用关系图Main()Menu()ReadfromFile()Answer()createLinkedList()Input()InsertNode()WritetoFile()Output()TorF()图1 函数调用关系图四、各函数功能说明1main() 主函数2Menu() 菜单函数3void Answer(int n,TEST * sp) 答题函数4void Output(TEST* ,int i) 输出第n道题题目5int TorF(TEST *sp,char m) 判卷函数6void Input(TEST *) 题目录入函数7void ReadfromFile(TEST* sp) 从文件中读取题目信息8TEST * createLinkedList(TEST*sp) 创建链表9TEST* InsertNode(TEST *head, TEST*s) 插入题目函数10void WritetoFile(TEST* head) 保存到文件五、流程图六、程序运行效果图1初始界面2随机抽题3答题并判卷4插入试题5保存到文件七、总结通过这短短5天的时间,学到了许多东西,尤其是对链表及文件的使用。在这之前对于链表和文件的使用还不是特别明白,现在已经可以较为熟练的应用它们。对结构体数组的使用也更加清晰了。在做单项选择题标准化考试系统时,碰到的第一个问题就是如何从文件里读取数据,为了解决这个问题,我细心的研究了老师给的课件,以及之前写过的学生成绩管理系统V6.0,最终解决了这个问题。碰到的第二个问题是,如何让编译器随机抽取的题目不重复,通过认真思考算法,最终得出了一个较为合理的算法。第三个问题是,链表的使用,在做“插入试题”这一块的函数时,经常出现编译错误的提示,仔细阅读编译器提供的错误信息,并对程序进行修改,最后也成功解决了这一个问题。这份程序在文件的读取和保存以及链表的使用方面参考了老师给的课件,并进行修改。但是,我的程序在图形处理上基本是没有,所以界面不是特别美观。通过网络资源,学会了清屏,system(“cls”);通过这次的课程设计,让我进一步的了解到C语言在我们日常生活中的重要性,体会到编一个对人们现实生活有用处的程序的快乐,更进一步的激发了我学习这门语言的兴趣.经过这次的训练,我相信自己以后会用更多的时间来把这门语言学好,掌握好这门必修的基础语言。最后,在此对我的C语言老师陈老师,表示感谢。感谢她平时认真地帮我调试程序,并耐心地解答疑点。在她的辅导下我从对C语言没有丝毫概念的程度到现在已经可以成功地写出一些比较像样的程序,是她开启了我的编程人生。八、参考文献1 邱建华C语言程序设计教程东软电子出版社,20092 谭浩强C程序设计(第三版)清华大学出版社,20053 邱建华C语言程序设计随堂实训及上机指导东北大学出版社,2007九、程序清单/*单项选择题标准化考试系统设计*/#include#include#include#include#include#define M 30typedef struct testchar problem300;char option1100;char option2100;char option3100;char option4100;char key;struct test *next;TEST;Menu(); /菜单函数void Answer(int n,TEST * sp); /答题函数void Output(TEST* ,int i); /输出第n道题题目int TorF(TEST *sp,char m); /判卷函数void Input(TEST *); /录入题目void ReadfromFile(TEST* sp); /从文件中读取题目信息TEST * createLinkedList(TEST*sp); /创建链表TEST* InsertNode(TEST *head, TEST*s); /插入函数void WritetoFile(TEST* head); /保存到文件int main(void)TEST testM;TEST s;TEST * head;int item,n;while(1)Menu();scanf(%d,&item);ReadfromFile(&test);switch(item)case 1: printf(请输入答题数:);scanf( %d,&n);Answer(n,&test);break;case 2:system(cls);Input(&s);head=createLinkedList(&test);head=InsertNode(head,&s); break;case 3:system(cls);WritetoFile(head);break;case 4:exit(0);break;default:printf(输入有误!请重新输入。n);/菜单函数Menu()printf(nt*单项选择题标准化考试系统*n);printf(t* 1.答题并判卷 *n);printf(t* 2.插入试题 *n);printf(t* 3.保存到文件 *n);printf(t* 4.退出程序 *n);printf(t*n);printf(tt请输入选项:);/答题函数void Answer(int n,TEST* sp)int i,j,score=0,numM;char m;srand(time(NULL);num0=rand()%(M-1)+0;for(i=0;i=0;j-) /保证不出现重复的题目if(numj=numj-1) /若抽中的题重复则重新抽题goto loop;Output(&spnumi,i+1); /输出抽中的题目printf(请输入答案:);scanf( %c,&m);score+=TorF(&spnumi,m); /判段用户输入的答案与标准答案是否一致printf(n你的总成绩为:%dn,score); /输出总成绩void Output(TEST *sp,int i) /输出第n道题题目函数printf(%d) ,i);printf( %sn,sp-problem);printf( A %s n,sp-option1);printf( B %s n,sp-option2);printf( C %s n,sp-option3);printf( D %s n,sp-option4);int TorF(TEST *sp,char m) /判卷函数if(sp-key=m) /若用户输入的答案与标准答案一致,返回1printf(Right!n);return 1;elseprintf(Wrong!n); /若用户输入的答案与标准答案不一致,返回0return 0;void Input(TEST *sp) /试题录入函数printf(请输入要插入的试题信息:n);printf(请输入题干:n);scanf( %s,sp-problem);printf(请输入选项 A:);scanf(%s,sp-option1);printf(请输入选项 B:);scanf(%s,sp-option2);printf(请输入选项 C:);scanf(%s,sp-option3);printf(请输入选项 D:);scanf(%s,sp-option4);printf(请输入答案:);scanf( %c,&sp-key);void ReadfromFile(TEST* sp) /文件读取函数 FILE * fp; int i; if(fp=fopen(test.txt,r) = NULL ) /文件打开失败 printf(Failure to open test.txt!n); exit(0); for(i=0;!feof(fp); i+) /文件打开成功 fscanf(fp, %s, blem); /将读出的数据保存在sp变量里 fscanf(fp,%s, spi.option1); fscanf(fp,%s, spi.option2); fscanf(fp,%s, spi.option3); fscanf(fp,%s, spi.option4); fscanf(fp, %c, &spi.key); fclose(fp); /关闭文件TEST * createLinkedList(TEST*sp) /创建链表int i;TEST*head=NULL,*q=NULL,*p=NULL; /定义三个变量for(i=0;inext=NULL;if(i=0)head=p; /链表的表头elseq-next=p;q=p;return head;TEST* InsertNode(TEST *head, TEST*s) /插入函数 int n,i; TEST*p,*q; p=head; q=p-next; printf(请输入要在哪个节点后插入题目信息:); scanf( %d, &n); for(i=0;q!=NULL & n!=i+1;i+) /遍历 p = p-next; q = q-next; if(q = NULL) printf(Not found!n); Else /插入数据 p-next = s; s-next = q; return head;void WritetoFile(TEST*head) /保存到文件 FILE * fp; TEST *q; if(fp = fopen(student.txt,w) = NULL ) /文件打开失败 printf(Failure to open file!n); exit

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论