C++单项选择题标准化考试系统
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
目录
1.课程设计目的 (1)
2.课程设计题目描述和要求 (1)
2.1 课程题目 (1)
2.2 课程要求 (1)
3.课程设计报告内容 (1)
3.1 算法描述 (1)
3.2 源程序 (2)
4.课程设计总结: (6)
5.参考书目 (7)
1课程设计目的
练习自己的动手能力 , 在学习理论的同时增强自己的编程能力 , 使理论与实践相结合 , 在学习书本的同时扩展自己的课外知识 .
2课程设计题目描述和要求
2.1 课程题目
单项选择题标准化考试系统
2.2 课程要求
(一)功能要求:
(1)用文件保存试题库。(每个试题包括题干、 4 个备选答案、标准答案)
(2)试题录入:可随时增加试题到试题库中
( 3)试题抽取:每次从试题库中可以随机抽出N 道题( N 由键盘输入)
(4)答题:用户可实现输入自己的答案
(5)自动判卷:系统可根据用户答案与标准答案的对比实现判卷并给出成绩。(二)其它要求:
(1)只能使用 C/C++语言,源程序要有适当的注释,使程序容易阅读
(2)至少采用文本菜单界面(如果能采用图形菜单界面更好)
(3)学生可自动增加新功能模块(视情况可另外加分)
(4)写出课程设计报告,具体要求见相关说明文档 .
3课程设计报告内容
3.1 算法描述
定义题目数组,选向数组,输入题目的及选向并给定正确答案。
输入所要答的题目数,然后进行答题。输入的答案与标准答案进行比较,如果一致,则正确,否则错误。最后根据题目数及答对题目数进行输出得分。
3.2 源程序
#include
#include
#include "dos.h"
using namespace std;
struct question {
char ask[200];/*选择题题目*/
char answer[4][80];/*选择题选项*/
int right;/*正确答案*/
struct question *next;
};
//函数声明
int MenuChoice(void); //选择菜单
struct question *charu_timu(struct question *fst,const struct question *ad); //向列表中插入试题函数
struct question *da_an_weizhi(struct question *seek, long len,long max); // 确定一个读取答案的位置的函数
void GetQuestion(struct question *src); //获取问题,选项,以及正确答案函数
void bao_cun(const struct question *ed, FILE *saf); //将列表中的试题保存在文件中的函数
struct question *LoadFile(struct question *td, FILE *laf); //从文件中读取题目,将题目添加到列表中的函数
int GetAnswer(void); //输入选择题的答案
void huida_Question(const struct question *que, int n); //回答问题函数
main()
{
struct question *start = NULL, temp;
long choice, line = 0, c;
FILE *fp = fopen("wangkun.dat", "a+");
while ((choice = MenuChoice()) != 3)
if (choice == 1)
{
GetQuestion(&temp);
start = charu_timu(start, &temp);
++line;/*统计列表的长度 */
system("cls");
}
else if (choice == 2)
{
c =8;
while (c > 6 || c > line) {
cout<<" 请输入要回答的问题数量: ";
cin>>c;
}
huida_Question(start, line);
}
return 0;
}
/*da_an_weizhi 函数确定一个读取答案的位置, len 代表要读取的答案数, max 代表列表的长度 */
struct question *da_an_weizhi(struct question *seek, long len, long max) {
int i;
while (i--)
seek = seek->next;//找到指定的位置
return seek;
}
// 向列表中插入试题
struct question *charu_timu(struct question *fst, const struct question *ad)
{
struct question *newPtr = (struct question *)malloc(sizeof(struct
question));
if (newPtr == NULL)
exit(0);
*newPtr = *ad;
newPtr->next = fst;
return newPtr;
}