结对编程 四则运算
一、需求分析:
设计一个可以进行加减乘除运算法的一个小程序 产生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]!='\0'){//将数字字符串转换成对应数值 true_result+=(result[i]-48)*pow(10,i); i++; } if(true_result==right){ accepted++; printf("计算正确!\n"); } else{ printf("计算错误!正确结果是:%d\n",right); } number++; fflush(stdin); } printf("测试结束!\n共%d道题目,通过%d道!\n",number,accepted); return 0; } void Menu()//菜单说明 { printf("\n\n"); printf("\t ---------程序说明----------\n"); printf("\t| 输入+号表示选择加法 |\n"); printf("\t| 输入-号表示选择减法 |\n"); printf("\t| 输入*号表示选择乘法 |\n"); printf("\t| 输入/号表示选择除法 |\n"); printf("\t| 输入00表示结束程序 |\n"); printf("\t ---------------------------\n"); printf("测试开始:\n"); } 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耗时表:
六、总结:
这次的结对编程,让我有学会了很多,和我的搭档李嫦慧虽然想法不一样但到最后还是达到了同样的共识,总体感觉还收不错的,从这个过程中还是学到了不了的东西。