zoukankan      html  css  js  c++  java
  • 结对编程 四则运算

    一、需求分析:

          设计一个可以进行加减乘除运算法的一个小程序 产生0~10之间的随机整数  当用户输入+号表示选择加法、输入-号表示选择减法  、 输入*号表示选择乘法 、 输入/号表示选择除法 、输入00表示结束程序  结束时统计计算结果。

    二、设计思路:

    1、定义 Calculation_formula();产生随机生成运算式;

    2、定义 number是总的测试题数,accepted是正确题数;

    3、 定义 temp随机生成0-3表示相应运算符;

    三、具体实现

    #include <stdio.h>
    #include <stdlib.h>
    #include <time.h>
    #include <math.h>
    #include <string.h>
    
    int right;
    
    void Menu();//菜单说明
    void Calculation_formula();//随机生成运算式
    void swap(int *a,int *b);//交换数值
    void reverse(char str[],int n);//数组逆转
    
    int main()
    {
        int number=0,accepted=0;
        //number是总的测试题数,accepted是正确题数
        int i,length,true_result;
        char result[5];
        Menu();
        while(1){
            i=0;
            true_result=0;
            Calculation_formula();
            scanf("%s",result);//以数字字符数组形式保存输入的结果
            if(result[1]=='0'&&result[0]=='0')//结束标志
                break;
            length=strlen(result);
            reverse(result,length);
            while(result[i]!=''){//将数字字符串转换成对应数值
                true_result+=(result[i]-48)*pow(10,i);
                i++;
            }
            if(true_result==right){
                accepted++;
                printf("计算正确!
    ");
            }
            else{
                printf("计算错误!正确结果是:%d
    ",right);
            }
            number++;
            fflush(stdin);
        }
        printf("测试结束!
    共%d道题目,通过%d道!
    ",number,accepted);
        return 0;
    }
    
    void Menu()//菜单说明
    {
        printf("
    
    ");
        printf("	 ---------程序说明----------
    ");
        printf("	|    输入+号表示选择加法    |
    ");
        printf("	|    输入-号表示选择减法    |
    ");
        printf("	|    输入*号表示选择乘法    |
    ");
        printf("	|    输入/号表示选择除法    |
    ");
        printf("	|    输入00表示结束程序     |
    ");
        printf("	 ---------------------------
    ");
        printf("测试开始:
    ");
    }
    
    void Calculation_formula()//运算式生成
    {
        int temp1,temp2;//保存随机生成的运算数
        char c;//保存运算符
        int temp;//随机生成0-3表示相应运算符
        srand((unsigned)time(NULL));//将当前时间设为随机函数种子
        temp=rand()%4;
        temp1=rand()%10;
        temp2=rand()%10;
        switch (temp){
            case 0://加法
                c='+';
                right=temp1+temp2;
                break;
            case 1://减法
                c='-';
                if(temp1<temp2)//结果非负
                    swap(&temp1,&temp2);
                right=temp1-temp2;
                break;
            case 2://乘法
                c='*';
                right=temp1*temp2;
                break;
            case 3://除法
                c='/';
                if(temp1==0&&temp2==0){//两运算数不能都是0
                    do{
                        temp1=rand()%10;
                        temp2=rand()%10;
                    }while(temp1||temp2);
                }
                if(temp1<temp2)//被除数应不小于除数
                    swap(&temp1,&temp2);
                if(temp2==0||temp1%temp2){//除数不能是0且相除不能有余数
                    do{
                       temp2=rand()%10;
                    }while(!temp2||(temp1%temp2));
                }
                right=temp1/temp2;
                break;
        }
        printf("%d%c%d=",temp1,c,temp2);
    }
    
    void swap(int *a,int *b)//交换数值
    {
        int p=*a;
        *a=*b;
        *b=p;
    }
    
    void reverse(char str[],int n)//将数组逆转
    {
        char c;
        int i;
        for(i=0;i<n/2;i++){
            c=str[i];
            str[i]=str[n-i-1];
            str[n-i-1]=c;
        }
    }
    

      四:测试结果及截图

    五、psp耗时表:

    六、总结:

    这次的结对编程,让我有学会了很多,和我的搭档李嫦慧虽然想法不一样但到最后还是达到了同样的共识,总体感觉还收不错的,从这个过程中还是学到了不了的东西。

  • 相关阅读:
    [POJ1176]Party Lamps(DFS,规律)
    [POJ1598]Excuses, Excuses!(模拟)
    [POJ2192]Zipper(DFS,剪枝)
    [POJ2157]Maze(DFS)
    [POJ1950]Dessert(DFS)
    [HIHO1353]满减优惠(状压,枚举)
    [HIHO1177]顺子(暴力,枚举)
    [HIHO1152]Lucky Substrings(暴力,枚举)
    计蒜客 25985.Goldbach-米勒拉宾素数判定(大素数) (2018 ACM-ICPC 中国大学生程序设计竞赛线上赛 B)
    计蒜客 28206.Runway Planning (BAPC 2014 Preliminary ACM-ICPC Asia Training League 暑假第一阶段第一场 F)
  • 原文地址:https://www.cnblogs.com/wxyz2598/p/4889453.html
Copyright © 2011-2022 走看看