zoukankan      html  css  js  c++  java
  • 四则运算生成器

    四则运算生成器

    1.代码来源:自己编写

    2.运行环境:VC++6.0

    3.编程语言:c语言

    4.bug:未发现

    5.当前功能:可以生成0-10的四则运算的题,在每道题做完后判断正确性和给出正确答案。

    5.功能扩展的方向:增加复合运算。

    6.gitbub代码地址:https://github.com/selfTboke/project1

    7.实现

    代码如下:

    #include <stdio.h>
    #include <stdlib.h>
    #include <time.h>
    #include <math.h>

    int main()
    {
    int type;
    int left, right,center;
    float result;
    srand(unsigned(time(NULL)));
    while(1)
    {
    //清屏
    system("cls");
    //生成随机数值
    type = rand() % 7;
    left = rand() % 10;
    right = rand() % 10;
    center = rand() % 10;

    switch(type)
    {
    case 0:
    printf("%d + %d = ?\n", left, right);
    scanf("%f", &result);
    if(left + right == result)
    printf("right!\n");
    else
    printf("wrong!The result is %d\n", left + right);
    break;
    case 1:
    //保证被减数大于减数
    if(left < right)
    break;
    printf("%d - %d = ?\n", left, right);
    scanf("%f", &result);
    if(left - right == result)
    printf("right!\n");
    else
    printf("wrong!The result is %d\n", left - right);
    break;
    case 2:
    printf("%d * %d = ?\n", left, right);
    scanf("%f", &result);
    if(left * right == result)
    printf("right!\n");
    else
    printf("wrong!The result is %d\n", left * right);
    break;
    case 3:
    //判断除数是否为0
    if(right == 0)
    break;
    printf("%d / %d = ?\n", left, right);
    printf("除不尽时请保留三位小数:");
    scanf("%f", &result);
    if(fabs(float(left) / right - result) <= 0.001 )
    printf("right!\n");
    else
    printf("wrong!The result is %.3f\n", float(left) / right);
    break;
    case 4:
    printf("%d + %d + %d = ?\n",left,center,right);
    scanf("%f",&result);
    if(left+center+right == result)
    printf("right!\n");
    else
    printf("wrong!The result is %d\n", left+center+right);
    break;
    case 5:
    if(left<(center+right))
    break;
    printf("%d - %d - %d = ?\n",left,center,right);
    scanf("%f",&result);
    if(left-center-right == result)
    printf("right!\n");
    else
    printf("wrong!The result is %d\n", left-center-right);
    break;
    case 6:
    if((left+center)<right)
    break;
    printf("%d + %d - %d = ?\n",left,center,right);
    scanf("%f",&result);
    if(left+center-right == result)

    else
    printf("wrong!The result is %d\n", left+center-right);
    break;
    }
    //防止闪退
    system("pause");

    }

    return 0;
    }

  • 相关阅读:
    JVM heap中各generation的大小(Sizing the Generations)
    MySQL中分组取第一条, 以及删除多余的重复记录
    八芯网线水晶头做法(线序)
    Win7命令行下查看无线网络信息
    OpenWrt的开机启动服务(init scripts)
    犀牛书的实例代码:给对象添加freeze, hide, 查询descriptors
    ES6新特性:Javascript中Generator(生成器)
    ES6新特性:Function函数扩展, 扩展到看不懂
    ES6新特性:Javascript中的Map和WeakMap对象
    ES6新特性:Javascript中Set和WeakSet类型的数据结构
  • 原文地址:https://www.cnblogs.com/selfTboke/p/7543350.html
Copyright © 2011-2022 走看看