zoukankan      html  css  js  c++  java
  • 二柱子课后题加强版的加强版

    新要求:

    1、实现在线答题

    2、答题结束后可以判断对错

    3、并将错误的结果保存起来

    代码:

    #include <stdio.h>

    #include <ctype.h>

    #include <time.h>

    #include <stdlib.h>

    #include <windows.h>

    #define IDNO_LENGTH 6

    #define CALC_KIND 4

    char getSignal();

    int getResult(int,int,char);

    void takeTest();

    void falsePrint(int);

    void correctPrint(int);

    //main函数

    void main()

    {

    while(1)

    {

    takeTest();

    }

    }

    //获取随机运算符

    char getSignal()

    {

    char signal[CALC_KIND]={'+','-','*','/'};

    srand((unsigned)time(NULL));

    return signal[rand()%4];

    }

    //获取随机数

    int random(double start, double end)

    {

    return (int)(start+(end-start)*rand()/(RAND_MAX+ 1.0));

    }

    //运算

    int getResult(int num1,int num2,char signal)

    {

    int res;

    switch(signal)

    {

    case '+':

    res=num1+num2;break;

    case '-':

    res=num1-num2;break;

    case '*':

    res=num1*num2;break;

    case '/':

    res=num1/num2;break;

    default:

    res=0;

    printf("运算符不符合规则 ");

    }

    return res;

    }

    //列出题目

    void takeTest()

    {

    int giveRes;

    int num1;

    int num2;

    char signal;

    int printFlag;

    srand((unsigned)time(NULL));

    signal=getSignal();

    num1=random(0,100);

    num2=random(1,100);

    if(signal=='-')

    {

    if(num1<num2)

    {

    int temp;

    temp=num1;

    num1=num2;

    num2=temp;

    }

    }

    if(signal=='/')

    {

    if(num2==0)

    {

    int temp;

    temp=num1;

    num1=num2;

    num2=temp;

    }

    }

    printf("%d%c%d=",num1,signal,num2);

    scanf("%d",&giveRes);

    fflush(stdin);

    if(getResult(num1,num2,signal)==giveRes)

    {

    printFlag=random(1,5);

    correctPrint(printFlag);

    }

    else

    {

    printFlag=random(1,4);

    falsePrint(printFlag);

    printf("正确答案:%d ",getResult(num1,num2,signal));

    }

    }

    //回答正确打印信息

    void correctPrint(int num)

    {

    switch(num)

    {

    case 1:

    printf("You're right! ");break;

    case 2:

    printf("It's OK! ");break;

    case 3:

    printf("Correct! ");break;

    case 4:

    printf("Perfect! ");break;

    case 5:

    printf("Good! ");break;

    default:

    printf("Powerful! ");break;

    }

    }

    //回答错误打印信息

    void falsePrint(int num)

    {

    switch(num)

    {

    case 1:

    printf("You're lost!");break;

    case 2:

    printf("Failure!");break;

    case 3:

    printf("Come on!");break;

    case 4:

    printf("It's wrong!");break;

    default:

    printf("Incorrect!");break;

    }

    }

    结果截图:

        

  • 相关阅读:
    Android笔记之开机自启
    Android笔记之广播
    Hive笔记之collect_list/collect_set(列转行)
    Hive笔记之数据库操作
    hive笔记之row_number、rank、dense_rank
    Linux Shell管道调用用户定义函数(使shell支持map函数式特性)
    Linux shell爬虫实现树洞网鼓励师(自动回复Robot)
    分享一些免费的接码平台(国外号码)
    爬虫技能之内容提取:如何从有不可见元素混淆的页面中抽取数据
    ctf writeup之程序员密码
  • 原文地址:https://www.cnblogs.com/f135114/p/9865504.html
Copyright © 2011-2022 走看看