文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C语言实现选择题标准化考试系统

2024-04-02 19:55

关注

本文实例为大家分享了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");
      }
    }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯