您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
本篇内容主要讲解“C语言如何实现选择题标准化考试系统”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言如何实现选择题标准化考试系统”吧!
1、用文件保存试题库。(每个试题包括题干、4个备选答案、标准答案)
2、试题录入:可随时增加试题到试题库中
3、试题抽取:每次从试题库中可以随机抽出N道题(N由键盘输入)
4、答题:用户可实现输入自己的答案
5、自动判卷:系统可根据用户答案与标准答案的对比实现判卷并给出成绩。
#include <stdio.h> #include <stdlib.h> #include <malloc.h> #define TRUE 1 #define ERROR 0 #define MAX 30 typedef int Status; typedef struct{ char option1[30],option2[30],option3[30],option4[30],subject[150]; char result; }TestNode; TestNode Testquestions[MAX]; Status SaveNode(int N) //把结构体数组保存到文件"qinhu"中,如成功保存返回TRUE,否则返回ERROR { int i; FILE *fp; if((fp=fopen("qinhu","wb"))==NULL) return ERROR; for(i=0;i<N;i++) fwrite(&Testquestions[i],sizeof(TestNode),1,fp); fclose(fp); return TRUE; } Status ReadNode(int N) //从文件读出结构体数组的内容,如成功读取返回TRUE,否则返回ERROR { FILE *fp; int i=0; if((fp=fopen("qinhu","rb"))==NULL) return ERROR; while(!feof(fp))// 用feof检测文件是否结束,如果结束,返回正确 { fread(&Testquestions[i],sizeof(TestNode),1,fp); i++; } N=i-1; return TRUE; } void InputTitle(int N)// 输入N道试题数据 { int i; for(i=0;i<N;i++) { printf("请输入第%d道题题目、题干和选项:\n",i+1);//输入结构体元素内容 printf("请输入题目:"); gets(Testquestions[i].subject); printf("请输入选项A:"); gets(Testquestions[i].option1); printf("请输入选项B:"); gets(Testquestions[i].option2); printf("请输入选项C:"); gets(Testquestions[i].option3); printf("请输入选项D:"); gets(Testquestions[i].option4); printf("请输入答案:"); scanf("%c",&Testquestions[i].result);getchar(); system("cls"); //清屏 } } Status InsertNodeA(int N) //输入试题内容 { if(N>MAX) return ERROR; printf("请输入所要输入题题目、题干和选项:\n"); printf("请输入题目:"); gets(Testquestions[N].subject); printf("请输入选项A:"); gets(Testquestions[N].option1); printf("请输入选项B:"); gets(Testquestions[N].option2); printf("请输入选项C:"); gets(Testquestions[N].option3); printf("请输入选项D:"); gets(Testquestions[N].option4); printf("请输入答案:"); scanf("%c",&Testquestions[N].result);getchar(); N++; //N表示结构体数组长度,通过加&号使其值能返回 return TRUE; } Status InsertNodeB(int N) //插入试题内容 { if(N>MAX) return ERROR; printf("请输入所要插入题题目、题干和选项:\n"); printf("请输入题目:"); gets(Testquestions[N].subject); printf("请输入选项A:"); gets(Testquestions[N].option1); printf("请输入选项B:"); gets(Testquestions[N].option2); printf("请输入选项C:"); gets(Testquestions[N].option3); printf("请输入选项D:"); gets(Testquestions[N].option4); printf("请输入答案:"); scanf("%c",&Testquestions[N].result);getchar(); N++; //N表示结构体数组长度,通过加&号使其值能返回 return TRUE; } Status DeleteNode(int n)//删除数组中的第n个元素 { return TRUE; } void printNode(TestNode p,int n)//输出第n道题题目 { printf("(%d) ",n); printf("%s\n",p.subject); printf(" A %s ",p.option1); printf(" B %s \n",p.option2); printf(" C %s ",p.option3); printf(" D %s ",p.option4); } Status Match(TestNode p,char m)//判断m是否为p题目的答案,若是返回TRUE,否则返回ERROR { if(m==p.result) return TRUE; else return ERROR; } void answer(int sum)//进行答题 { int i,score=0,Num; char r; for(i=1;i<=sum;i++) { Num= rand()%sum; //随机函数,以随机选定何题进行解答 printNode(Testquestions[Num],Num+1); printf("\n请输入答案:"); scanf("%c",&r);getchar(); if( Match(Testquestions[Num],r)) //调用函数IsMatch判断所输入的答案与标准答案是否相同 { printf("\n答案正确!\n"); score++; } else printf("\n答案错误!\n"); } printf("\n你的总成绩为:%d\n",score); } void main() { char flag='N'; int N=0,i, sum,score=0,chose; printf("输入想建立的题目文件题目数:"); scanf("%d",&N);getchar(); InputTitle(N); ReadNode(N); while(flag=='N'||flag=='n') { printf("\t\t\t单项选择题标准化考试系统\n "); printf("\n"); printf(" \t\t\t1 进行答题并判卷\n"); printf(" \t\t\t2 显示整张试卷内容\n"); printf(" \t\t\t3 插入试题\n"); printf(" \t\t\t4 保存到文件\n"); printf(" \t\t\t5 退出系统\n"); printf(" \t\t\t 请选择:"); scanf("%d",&chose);getchar(); switch(chose) { case 1:system("cls"); printf("请输入你想要的答题数目:"); scanf("%d",&sum);getchar(); answer(sum); break; case 2:system("cls"); for(i=1;i<=N;i++) { printNode(Testquestions[i-1],i); printf("\n"); } break; case 3:system("cls");InsertNodeB(N);break; case 4:system("cls"); if(SaveNode(N)) printf("保存成功!\n"); else printf("保存失败!\n");break; case 5:printf("你将退出系统(Y or N)?"); scanf("%c",&flag);getchar(); if(flag=='Y'||flag=='y') exit(0); system("cls");break; default:printf("请输入正确选择!\n"); } } }
到此,相信大家对“C语言如何实现选择题标准化考试系统”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。