zoukankan      html  css  js  c++  java
  • 实验一(小学四则运算练习系统)

    #include <stdio.h>
    #include <stdlib.h>
    
    int getChoice();
    void showMenu();
    void doExercise(int);
    int test(int);
    
    int getChoice()
    {
        int choice;
        scanf("%d",&choice);
        return choice;
    }
    
    void showMenu()
    {
        printf("===================================\n");
        printf("\n欢迎使用小学四则运算练习软件\n");
        printf("\n");
        printf("\t1、加法练习\t2、减法练习\n");
        printf("\t3、乘法练习\t4、除法练习\n");
        printf("\t5、综合练习\t0、退出系统\n");
        printf("\n");
        printf("请输入你的选择(0--5):\n");
        printf("\n===================================\n");
    }
    
    
    void doExercise(int n)
    {
        int count=0;
        int score=0;        //练习得分,初始化为0
        int i=0;            //练习题数的计数器
        
        for(i=1;i<=10;i++)
        {
            count=count+test(n);        //间接递归调用test(n)
            score=count*10;
        }
        printf("本次练习十道题,你做对了%d道,所得分数为%d分\n",count,score);
    }
    
    /*
        功能:进行一道题的测试过程
    */
    int test(int n)
    {
        int ranswer=0;            //正确答案
        int uanswer=0;            //用户输入的答案
        int t=0;                //临时变量
        char operation;            //运算类别
        int num1=0;                //操作数1
        int num2=0;                //操作数2
    
        srand(time(NULL));        //初始化随机数种子
        num1=rand()%10;            //取0—9之间的随机数
        num2=rand()%10;
    
        //进入程序功能,如果选择5就随机产生1-4所代表的每一种运算方式
        if(n==5)
        {
            n=rand()%4+1;
        }
    
        switch(n)
        {
            case 1:
                operation='+';
                break;
    
            case 2:
                operation='-';
                break;
    
            case 3:
                operation='*';
                break;
    
            case 4:
                operation='/';
                break;
        }
    
    /*加入一条防止“不够减”的语句,当选择减法且num1小于num2时不够减
    的时候,用临时变量交换两个操作数*/
    
        if((operation=='-') && (num1<num2))
        {
            t=num1;
            num1=num2;
            num2=t;
        }
    
    /*防止“除数为0”的程序漏洞,当num2被随机取值到0时,就将num2强制置为1
    做除法时,将num1的值强制赋值给num1*num2,防止不能整除*/
    
        if(operation=='/')
        {
            if(num2==0)
            {
                num2=1;
            }
            num1=num1*num2;            //防止num1不能被num2整除的语句
        }
    
    //输出测试题本身、提示用户输入
        printf("%d%c%d= ",num1,operation,num2);
        scanf("%d",&uanswer);
    
    //程序计算正确结果
        switch(operation)
        {
            case '+':
            ranswer=num1+num2;
            break;
    
            case '-':
            ranswer=num1-num2;
            break;
    
            case '*':
            ranswer=num1*num2;
            break;
    
            case '/':
            ranswer=num1/num2;
            break;
        }
    //评判,做对返回1,做错返回0
        if(uanswer==ranswer)
        {
            printf("做对了!\n");
            return 1;
        }
        else 
        {
            printf("做错了!\n");
            return 0;
        }
    }
    
    
    //主函数
    int main(void)
    {
        int choice=0;        //接收用户的选择
        
        
        
        //循环开始功能,本次用do……while循环
        do
        {
            showMenu();                //显示菜单
            choice=getChoice();        
    
            //控制choice的范围
            if(choice<0 || choice>5)
            {
                choice=1;            //强制做加法
            }
            if(choice==0)
            {
                break;                    //用户选择0,退出循环(退出系统)
            }
    
            doExercise(choice);        //做什么练习,并启动评分
        }while(choice!=0);
    
        printf("欢迎使用本软件,再见!\n");
        return 0;
    }

    虽然代码写得比较简单,功能也还没达到老师的要求,但是这种层次分明的写法还是比较喜欢。功能有待改进...

  • 相关阅读:
    JS项目快速压缩(windows平台)
    Maven工程的POM继承
    Docker构建一个node镜像
    win10家庭版安装Docker for Windows
    linux,vim和bash命令小册
    vue文档阅读笔记——计算属性和侦听器
    nodejs的jekins部署
    `vue-router`的`History`模式下的项目发布
    花式图表,炫技时刻!PPT技能
    在创业之路上不断创新
  • 原文地址:https://www.cnblogs.com/santokim/p/4377151.html
Copyright © 2011-2022 走看看