小学生测验管理

2024-02-12 01:38
文章标签 管理 测验 小学生

本文主要是介绍小学生测验管理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

#include<stdio.h>
#include<stdlib.h>
#include<time.h>   //随机取数用到它
struct Student
{
 char name[15];
 int number;
 int age;
 int score;
}stu;    //定义名为stu的结构体

void meun()  //主界面
{
 printf("****************************************\n");
 printf("***********小学数学测试软件*************\n");
 printf("                                        \n");
 printf("         一 二 年 级 测 试 题           \n");
    printf("                                        \n");
 printf("**** [1] 进入测试      [0] 退出测试 ****\n");
 printf("****************************************\n");
}

 /*编译成功进入下图测试界面,选择1,按要求输入学号,姓名,年龄后进入测试界面*/

void ceshi()   //测试界面
{
    printf("*********************************************\n");
    printf("***********小学数学测试软件*************\n");
    printf("                                                                    \n");
    printf("       [1]加法测试    [2]减法测试                \n");
    printf("                                                                   \n");
    printf("****   [3]混合测试    [0]退出测试   ****    \n");
    printf("****************************************\n");

/*在测试界面可根据需要输入数字进入相关界面*/


}

int c,d,a,b,q;   //定义全局变量  a,b为随机数,c表示加法,d表示减法,q控制返回测试界面
void add()
{  
 system("cls");      //清屏
 printf("*******************************************************************\n");
 printf("************************* -= 加法测试 -= ***********************\n");
 printf("*******************************************************************\n");
 int i,k,t;
 stu.score=0;
 srand(time(NULL));//用当前时间,设置种子
 for(i=0;i<10;)    //当0<c<50时,i++
 { 
       a=rand()%50;
     b=rand()%50;
     c=a+b;
  if(c>0&&c<50)
  {
   i++;
   printf("第%d题:%d+%d=",i,a,b);   
   for(t=3;t>0;t--)
   {
                scanf("%d",&k);
    if(k==c)
    {
     switch(t)
     {     
         case 1: stu.score+=5;break;
      case 2: stu.score+=7;break;
      case 3: stu.score+=10;break;
     }
        break;
       }
    else
    {
     printf("答案错误,你还有%d次机会\n",t-1);
     if((t-1)==0) printf("正确答案:%d\n",c);
    }
   }
  }
 }
 printf("你的总成绩为%d分\n",stu.score);
}
              
void sub()
{
    system("cls");
    printf("*******************************************************************\n");
 printf("************************* -= 减法测试 -= **************************\n");
 printf("*******************************************************************\n");
    int i,k,t;
    stu.score=0;
 srand(time(NULL));//用当前时间,设置种子
 for(i=0;i<10;)
 { 
       a=rand()%50;
     b=rand()%50;
     d=a-b;
  if(d>0&&d<50)
  {
   i++;
         printf("第%d题:%d-%d=",i,a,b);  
   for(t=3;t>0;t--)
   {  
                scanf("%d",&k);
    if(k==d)
    {
     switch(t)
     {     
         case 1: stu.score+=5;break;
      case 2: stu.score+=7;break;
      case 3: stu.score+=10;break;
     }
        break;
       }
    else
    {
     printf("答案错误,你还有%d次机会\n",t-1);    
     if((t-1)==0) printf("正确答案:%d\n",d);
    }
   }
  }
 }
 printf("你的总成绩为%d分\n",stu.score);
}

void mix()
{
    system("cls");
    printf("*******************************************************************\n");
 printf("************************* -= 加减测试 -= **************************\n");
 printf("*******************************************************************\n");
 int i,k,t,p;
 srand(time(NULL));//用当前时间,设置种子
 stu.score=0;
 for(p=0;p<10;p++)
 {      
    i=rand()%2;
    switch(i)
    {
       case 0:
      while(1)
      {
                   a=rand()%50;
                   b=rand()%50;
       c=a+b;
       if(c>0&&c<50)
       {
                       printf("第%d题:%d+%d=",p+1,a,b);  
              for(t=3;t>0;t--)
        {  
                          scanf("%d",&k);
               if(k==c)
        {
              switch(t)
        {     
                  case 1: stu.score+=5;break;
                 case 2: stu.score+=7;break;
               case 3: stu.score+=10;break;
        }
                 break;
        }
              else
        {
               printf("答案错误,你还有%d次机会\n",t-1);    
               if((t-1)==0) printf("正确答案:%d\n",c);
        }
        }
        break;
       }
      }break;
    case 1:
      while(1)
      {
                   a=rand()%50;
                   b=rand()%50;
       d=a-b;
       if(d>0&&d<50)
       {
                       printf("第%d题:%d-%d=",p+1,a,b);  
              for(t=3;t>0;t--)
        {  
                          scanf("%d",&k);
               if(k==d)
        {
              switch(t)
        {     
                  case 1: stu.score+=5;break;
                 case 2: stu.score+=7;break;
               case 3: stu.score+=10;break;
        }
                 break;
        }
              else
        {
               printf("答案错误,你还有%d次机会\n",t-1);    
               if((t-1)==0) printf("正确答案:%d\n",d);
        }
        }
        break;
       }
      }break;
    }
 }
 printf("你的总成绩为%d分\n",stu.score);
}
   
void dengji()
{
 if(stu.score>=90)
  printf("SMART\n");
 else if(stu.score>=80) printf("GOOD\n");
 else if(stu.score>=70) printf("OK\n");
 else if(stu.score>=60) printf("PASS\n");
 else printf("TRY AGAIN\n");
 printf("按 0 返回测试界面:");
 scanf("%d",&q);
}

void save()
{
 FILE *fp;
 if((fp=fopen("pupil.dat","wb"))==NULL)
 {
  printf("cannot open file\n");
  return;
 }
 if(fwrite(&stu,sizeof(struct Student),1,fp)!=1)
  printf("file write error\n");
 fclose(fp);
}

void load()
{
 FILE *fp;
 if((fp=fopen("pupil.dat","rb"))==NULL)
 {
  printf("cannot open infile\n");
  return;
 }
 if(fread(&stu,sizeof(struct Student),1,fp)!=1)
 {
  if(feof(fp))
  {
   fclose(fp);
   return;
  }
  printf("file read error\n");
 }
 fclose(fp);
}

int main()
{
 int z,r;
 load();
 meun();
 while(1)
 {
  printf("请选择:");
  scanf("%d",&z);
  if(z>1||z<0)
  {
   printf("没有该选项,请重新输入!\n");
   continue;
  }
  switch(z)
  {
      case 1:
       printf("请输入学号:");
       scanf("%d",&stu.number);
       printf("请输入你的姓名:");
       scanf("%s",stu.name);
       printf("请输入你的年龄:");
       scanf("%d",&stu.age);
                   B:system("cls");
       ceshi();
       while(1)
       {
        printf("请选择测试内容:");
        scanf("%d",&r);
                       if(r>3||r<0)
        {
                   printf("没有该选项,请重新输入!\n");
                   continue;
        }
        switch(r)
        {
            case 1:add();save();dengji();if(q==0) goto B;;
         case 2:sub();save();dengji();if(q==0) goto B;
         case 3:mix();save();dengji();if(q==0) goto B;
         case 0:exit(0);break;
        }
       }
       break;
   case 0:exit(0);break;
  }
 }
 return 0;
}

 

 

 

 

 

 

这篇关于小学生测验管理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/701353

相关文章

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

软考系统规划与管理师考试证书含金量高吗?

2024年软考系统规划与管理师考试报名时间节点: 报名时间:2024年上半年软考将于3月中旬陆续开始报名 考试时间:上半年5月25日到28日,下半年11月9日到12日 分数线:所有科目成绩均须达到45分以上(包括45分)方可通过考试 成绩查询:可在“中国计算机技术职业资格网”上查询软考成绩 出成绩时间:预计在11月左右 证书领取时间:一般在考试成绩公布后3~4个月,各地领取时间有所不同

安全管理体系化的智慧油站开源了。

AI视频监控平台简介 AI视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。用户只需在界面上进行简单的操作,就可以实现全视频的接入及布控。摄像头管理模块用于多种终端设备、智能设备的接入及管理。平台支持包括摄像头等终端感知设备接入,为整个平台提

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

Sentinel 高可用流量管理框架

Sentinel 是面向分布式服务架构的高可用流量防护组件,主要以流量为切入点,从限流、流量整形、熔断降级、系统负载保护、热点防护等多个维度来帮助开发者保障微服务的稳定性。 Sentinel 具有以下特性: 丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应

NGINX轻松管理10万长连接 --- 基于2GB内存的CentOS 6.5 x86-64

转自:http://blog.chinaunix.net/xmlrpc.php?r=blog/article&uid=190176&id=4234854 一 前言 当管理大量连接时,特别是只有少量活跃连接,NGINX有比较好的CPU和RAM利用率,如今是多终端保持在线的时代,更能让NGINX发挥这个优点。本文做一个简单测试,NGINX在一个普通PC虚拟机上维护100k的HTTP

PMBOK® 第六版 规划进度管理

目录 读后感—PMBOK第六版 目录 规划进度管理主要关注为整个项目期间的进度管理提供指南和方向。以下是两个案例,展示了进度管理中的复杂性和潜在的冲突: 案例一:近期,一个长期合作的客户因政策要求,急需我们为多家医院升级一个小功能。在这个过程中出现了三个主要问题: 在双方确认接口协议后,客户私自修改接口并未通知我们,直到催进度时才发现这个问题关于UI设计的部分,后台开发人员未将其传递给

PHP原理之内存管理中难懂的几个点

PHP的内存管理, 分为俩大部分, 第一部分是PHP自身的内存管理, 这部分主要的内容就是引用计数, 写时复制, 等等面向应用的层面的管理. 而第二部分就是今天我要介绍的, zend_alloc中描写的关于PHP自身的内存管理, 包括它是如何管理可用内存, 如何分配内存等. 另外, 为什么要写这个呢, 因为之前并没有任何资料来介绍PHP内存管理中使用的策略, 数据结构, 或者算法. 而在我们

C++学习笔记----6、内存管理(四)---- 通常的内存陷阱(2)

3、Windows环境下使用Visual C++发现并修复内存渗露         内存渗露很难跟踪是因为你无法很容易地看着内存并且看到什么对象处于使用中,一开始在哪儿分配的内存。然而,是有程序可以为你做到这一点的。内存渗露检测工具有昂贵的专业软件包,也有免费下载的工具。如果你是在Microsoft Visual C++环境下工作,它的排错工具库有内建的对于内存渗露检测的支持。该内存检测默认没有

FreeRTOS学习笔记(四)Freertos的中断管理及临界保护

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、Cortex-M 中断管理1.1 中断优先级分组1.2 相关寄存器1.3 相关宏定义1.4 FreeRTOS 开关中断 二、临界段及其保护2.1 taskENTER_CRITICAL( ) 和 taskEXIT_CRITICAL( )2.2 taskENTER_CRITICAL_FROM_ISR( )