c++求解,一道关于计算机随机产生10道四则运算题通过计算机随机产生10道四则运算题,两个操作数为1~10之间的随机数,运算类型为随机产生的加、减、乘、整除中的任意一种,如果输入答案正

来源:学生作业帮助网 编辑:作业帮 时间:2024/08/10 03:52:24
c++求解,一道关于计算机随机产生10道四则运算题通过计算机随机产生10道四则运算题,两个操作数为1~10之间的随机数,运算类型为随机产生的加、减、乘、整除中的任意一种,如果输入答案正
xVOVW\M HRISZ&iڃcUZ aP OMMH!!|':&a^8;ǽ(70߿2hoͭSjFyk\z,6JnWn9*ɾ^FWjmQ˭3#7O@D#}A zϡD&|Yk K u<_BlBlF)I\ eK1 2 'ÛMc1';4cQ⢲,pDWSF}:eHmG T^AU,4l PrѨC8^G X9(5D$o+`n?dӫ71*eP\0V+c 4@ed}lpQ, mlmPfF חI30@w<ݭ7h!i-z N>]7k?.8 [նY\'Y+J*E}? ,MY?a? 1e%.uϕ$'Jvm ! CBi m%ҝdqQIQ1mzH !8 hn=a{ }%TVeS'ZDcw m':,?$h"„J[dK+ &K5@n HA-|?^n7h/P(7(/~e…^m26p-3*m&U[n)+X|VhZy&r"X>>^@_Fڮʠ[]!^nR;^|{RBjz'30f3) ^/#Է;ds,9{IO֜ڼäNuxX x9{q{pڞn!pnґg{ (GlךnP%ݹ?h飨 ~^TYL'?!wG:lDqg?[8Z8"zrv]B?,C3;8ݲ9r8I?I❢^?^.&#)<5)w2gFYcSQ U=d] ڹ w@lH9 5{nCpo3x%إ>u+=3޹1Wotj`q.jnA*hWng< b+ZOOcS

c++求解,一道关于计算机随机产生10道四则运算题通过计算机随机产生10道四则运算题,两个操作数为1~10之间的随机数,运算类型为随机产生的加、减、乘、整除中的任意一种,如果输入答案正
c++求解,一道关于计算机随机产生10道四则运算题
通过计算机随机产生10道四则运算题,两个操作数为1~10之间的随机数,运算类型为随机产生的加、减、乘、整除中的任意一种,如果输入答案正确,则显示“Right!”,否则显示“Not correct!”,不给机会重做,10道题做完后,按每题10分统计总得分,然后打印出总分和做错题数.
使用子函数实现两个数相加的测试.此函数的输入参数是两个加数,返回值是用户运算的正确与否(用1或者0表示).在此函数中首先读入用户输入的加法结果,并与正确结果进行比较.
int AddTest(int a, int b) ;

c++求解,一道关于计算机随机产生10道四则运算题通过计算机随机产生10道四则运算题,两个操作数为1~10之间的随机数,运算类型为随机产生的加、减、乘、整除中的任意一种,如果输入答案正
#include
#include
#include
#include
using std::cin;
using std::cout;
using std::endl;
//计算式 数量
int const Num = 10;
//计算式中 最大数
int const MaxNum = 10;
enum enOp{Add,Subtract,Multiply,Divide};
//加法
int addFun(int left,int right)
{
return left + right;
}
//减法
int subFun(int left,int right)
{
return left - right;
}
//乘法
int mulFun(int left,int right)
{
return left * right;
}
//除法
int divFun(int left,int right)
{
return left / right;
}
//将 枚举类型转换为字符类型,以便输出.
char enum2char(enOp op)
{
switch (op)
{
case Add:
return '+';
case Subtract:
return '-';
case Multiply:
return 'x';
case Divide:
return '/';
}
return ' ';
}
//计算生成表达式的正确结果.
int myResult(int left,int right,enOp op)
{
switch (op)
{
case Add:
return addFun(left ,right);
case Subtract:
return subFun(left ,right);
case Multiply:
return mulFun(left ,right);
case Divide:
return divFun(left ,right);
}
return 0;
}
//检查生成计算式的正确与否.其中 减法结果不能为负数,除法结果不能为小数.
bool checkFormula(int left,int right,enOp op)
{
switch (op)
{
case Add:
return true;
case Subtract:
{
if(left < right)
return false;
return true;
}
case Multiply:
return true;
case Divide:
{
if(double(left/right) != double(double(left)/double(right)))
return false;
return true;
}
}
return false;
}
//依据给定操作符,生成符合条件的表达式.
void getFormula(int* left,int*right,enOp op)
{
//srand(time(NULL));
for(;;)
{
*left = 1 + rand() % MaxNum;
*right = 1 + rand() % MaxNum;
if(checkFormula(*left,*right,op))
break;
}
}
int main()
{
//操作符左值
int left[Num];
//操作符右值
int right[Num];
//用户输入计算结果
int result[Num];
//操作符 +-*/
enOp oper[Num];
//正确答案个数
int answerRight = 0;
cout