题目要求:

1、避免题目重复

2、可定制(数量/打印方式)

3、可以控制下列参数

(1)是否有乘除法

(2)是否有括号

(3)数值范围

(4)加减有无负数

(5)除法有无余数

关键设计思想:

operationSymbol(int &isMulAndDiv)用于确定运算式是否有乘除法

DivisorNotZore(int &Divisor,int RangeNum)用于保证除数不为0

Remainder(int number1,int &number2,int RangeNum)用于保证没有余数

Neg(int number1,int &number2,int RangeNum)用于避免减法出现负数

若用户选择有括号的运算式,程序通过循环一下步骤依次得到运算式:

1、通过随机数取得运算式中数的个数,执行2。

2、通过循环在0,1之间取随机数判断是否出现左括号,存放在problems[1000][100]相应位置,Rbr记录出现的次数,leftParenthese[100]记录左括号在表达式中的位置,执行3。

3、通过随机数取得数,存入number数组相应位置,在problems[1000][100]相应位置用字符‘n'代替存储,执行4。

4、通过循环在0,1之间取随机数判断是否出现左括号,若出现,则与右括号匹配,同时排除无意义的括号,执行5。

5、在输入最后一个数之前通过随机数0-4选择运算符,将运算符存放在problems[1000][100]相应位置,执行6。

6、执行2,直到输入数的个数符合条件执行7。

7、判断这个运算式是否与前面的运算式重复,若重复,则舍弃这个运算式,重新执行1。

若用户选择没有括号的运算式,程序选择通过循环下列步骤依次得到运算式:

1、通过随机数取得运算式中数的个数,执行2。

2、通过通过随机数取得数,存入number数组相应位置,在problems[1000][100]相应位置用字符‘n'代替存储,执行3。

3、在输入最后一个数之前通过随机数0-4选择运算符,将运算符存放在problems[1000][100]相应位置,执行4

4、执行2,直到输入数的个数符合条件执行5。

5、判断这个运算式是否与前面的运算式重复,若重复,则舍弃这个运算式,重新执行1。

若用户选择在屏幕上显示运算式,则依次将存放在problems的字符显示出来,遇到字符’n',则输出对应数字

若用户选择在problems.txt文件中保存运算式,则依次将存放在problems的字符输入到文件中,遇到字符’n',则输入对应数字

源程序代码:

//2016 3.6 Cheng Qiqin
//四则运算改进
#include <iostream>
#include<ctime>
#include<cstdlib>
#include<iomanip>
#include<fstream>
using namespace std; void proNum(int &ProNum)//确定题目数量
{
cout<<"请输入运算式的数量: ";
cin>>ProNum;
if(ProNum<)
{
cout<<"输入错误,";
proNum(ProNum);
}
} void typeway(int &type)//确定打印方式
{
cout<<"请输入打印方式(1、输出到屏幕 2、输出到文件): ";
cin>>type;
if(type>||type<)
{
cout<<"输入错误,";
typeway(type);
}
} void ismulAndDiv(int &isMulAndDiv)//确定是否有乘除法
{
cout<<"是否有乘除法(1、是 2、否):";
cin>>isMulAndDiv;
if(isMulAndDiv<||isMulAndDiv>)
{
cout<<"输入错误,";
ismulAndDiv(isMulAndDiv);
}
} int operationSymbol(int &isMulAndDiv)//确定是否有乘除法
{
if(isMulAndDiv==)
{
return ;
}
else
{
return ;
}
} void isparenthese(int &isParenthese)//确定是否有括号
{
cout<<"是否有括号(1、是 2、否): ";
cin>>isParenthese;
if(isParenthese<||isParenthese>)
{
cout<<"输入错误,";
isparenthese(isParenthese);
}
} void isneg(int &isNeg)//确定加减有无负数
{
cout<<"加减有无负数(1、有 2、无): ";
cin>>isNeg;
if(isNeg<||isNeg>)
{
cout<<"输入错误,";
isneg(isNeg);
}
} void isremainder(int &isRemainder)//确定除法有无余数
{
cout<<"除法有无余数(1、有 2、无): ";
cin>>isRemainder;
if(isRemainder<||isRemainder>)
{
cout<<"输入错误,";
isremainder(isRemainder);
}
} void DivisorNotZore(int &Divisor,int RangeNum)//排除除数为0
{
while(Divisor==)
{
Divisor=rand()%RangeNum;
}
} void Neg(int number1,int &number2,int RangeNum)//排除形如a-b结果为负的情况
{
while(number1<number2)
{
number2=rand()%RangeNum;
}
} void Remainder(int number1,int &number2,int RangeNum)//排除有余数的情况
{
while((number1%number2)!=)
{
number2=rand()%RangeNum;
DivisorNotZore(number2,RangeNum);
}
} void main()
{
srand((int)time()); //设定时间种子
int ProNum,type,isMulAndDiv,isParenthese,RangeNum,isNeg,isRemainder;
int number[][],Prolength[],Rbr=,num,i,j,n; //number[100][10]用于存放每个表达式中数字,Prolength[100]用于记录表达式的长度
char Problems[][];// Problems[100][100]用于存放表达式
char fuhao[]={'+','-','*','/'};
proNum(ProNum);
typeway(type);
ismulAndDiv(isMulAndDiv);
isparenthese(isParenthese);
isneg(isNeg);
if(isMulAndDiv==)
{
isremainder(isRemainder);
}
cout<<"请输入数值范围:"<<endl;
cout<<"请输入上限:";
cin>>RangeNum;
if(RangeNum<){
cout<<"输入错误,请重新输入上限:";
cin>>RangeNum;
} if(isParenthese==)//有括号
{
for(i=;i<ProNum;i++)
{
num=rand()%+;//随机得出每个表达式中数的个数
j=;
int leftParenthese[],loc=;
if(num==)//运算式中只有两个数时,不需要括号
{
for(n=;n<num;n++)
{
Problems[i][j]='n';
number[i][n]=rand()%RangeNum;
if(Problems[i][j-]=='/')//排除除号后面的数为0的情况
{
DivisorNotZore(number[i][n],RangeNum);
}
j++;
if(n<num-)//添加运算符
{
Problems[i][j]=fuhao[rand()%operationSymbol(isMulAndDiv)];
j++;
}
}
Prolength[i]=j;//记录运算式的长度
}
else//运算式中数超过两个,出现括号
{
for(n=;n<num;n++)
{
while(rand()%)//添加左括号
{
Rbr++;
Problems[i][j]='(';
leftParenthese[loc]=j;
loc++;
j++;
}
Problems[i][j]='n';
number[i][n]=rand()%RangeNum;//排除除号后面的数为0的情况
if(Problems[i][j-]=='/')
{
DivisorNotZore(number[i][n],RangeNum);
}
j++;
while(rand()%==)//添加右括号
{
if(Rbr>)
{
Rbr--;
loc--;
if(Problems[i][j-]=='(')//排除形如(20)的情况
{
Problems[i][j-]=Problems[i][j-];
j--;
}
else
{
if(Problems[i][leftParenthese[loc]]=='('&&Problems[i][leftParenthese[loc]+]=='('&&Problems[i][j-]==')')
{
for(int loction=leftParenthese[loc];loction<j-;loction++)
{
Problems[i][loction]=Problems[i][loction+];
}
j--;
}
else
{
Problems[i][j]=')';
j++;
}
}
}
else{
break;
}
}
if(n<num-)//添加运算符
{
Problems[i][j]=fuhao[rand()%operationSymbol(isMulAndDiv)];
j++;
}
}
while(Rbr>)//保证左括号数量与右括号数量相等
{
Rbr--;
loc--;
if(Problems[i][j-]=='(')//排除形如(20)的情况
{
Problems[i][j-]=Problems[i][j-];
j--;
}
else
{
if(Problems[i][leftParenthese[loc]]=='('&&Problems[i][leftParenthese[loc]+]=='('&&Problems[i][j-]==')')
{
for(int loction=leftParenthese[loc];loction<j-;loction++)
{
Problems[i][loction]=Problems[i][loction+];
}
j--;
}
else
{
Problems[i][j]=')';
j++;
}
}
}
Prolength[i]=j;
}
for(int k=;k<i;k++)//排除运算式重复
{
if(Problems[k]==Problems[i])
{
i--;
break;
}
}
}
}
else
{
for(i=;i<ProNum;i++){
num=rand()%+;
j=;
for(n=;n<num;n++){
Problems[i][j]='n';
number[i][n]=rand()%RangeNum;
if(Problems[i][j-]=='/')//排除除号后面的数为0的情况
{
DivisorNotZore(number[i][n],RangeNum);
}
j++;
if(n<num-)//添加运算符
{
Problems[i][j]=fuhao[rand()%operationSymbol(isMulAndDiv)];
j++;
}
}
Prolength[i]=j;//记录运算式的长度
for(int k=;k<i;k++)//排除重复
{
if(Problems[k]==Problems[i])
{
i--;
break;
}
}
}
}
int s,t,q;
ofstream of("problems.txt");
if(!of)
exit();
for(i=;i<ProNum;i++)//表达式数量
{
s=;
t=;
q=Prolength[i];
while(Problems[i][s]=='('&&Problems[i][q-]==')')//排除表达式首尾都有括号且无意义时的情况
{
int m,n=;
bool kuohao=true;
for(m=s;m<q-;m++)
{
if(Problems[i][m]=='(')
{
n++;
}
if(Problems[i][m]==')')
{
n--;
}
if(n==)
{
kuohao=false;
break;
}
}
if(kuohao)
{
s++;
Prolength[i]=Prolength[i]-;
q=q-;
}
else
{
break;
}
}
while(Prolength[i]>)
{
if(Problems[i][s]=='n')
{
if(t>)
{
if(isNeg==)
{
if(Problems[i][s-]=='-'&&Problems[i][s-]=='n')
{
Neg(number[i][t-],number[i][t],RangeNum);
}
}
if(isRemainder==)
{
if(Problems[i][s-]=='/'&&Problems[i][s-]=='n')
{
Remainder(number[i][t-],number[i][t],RangeNum);
}
}
}
if(type==)
{
cout<<number[i][t];
}
else
{
of<<number[i][t];
}
s++;
t++;
}
else
{
if(type==)
{
cout<<Problems[i][s];
}
else
{
of<<Problems[i][s];
}
s++;
}
Prolength[i]--;
}
if(type==)
{
cout<<"="<<endl;
}
else
{
of<<"="<<endl;
}
}
of.close();
if(type==)
{
cout<<"出题完毕!"<<endl;
}
else
{
cout<<"出题完毕,题目已成功存入problems.txt!"<<endl;
}
}

运行结果截图:

项目计划日志:(单位:min)

时间记录日志:

缺陷记录日志:

程序已实现功能:

避免题目重复

可定制(数量/打印方式)

可以控制下列参数

(1)是否有乘除法

(2)是否有括号

(3)数值范围

程序部分实现功能:

(4)加减有无负数

(5)除法有无余数

未实现部分:

未能实现运算式的计算

未实现原因:

不能预测括号中计算后出现的结果

实现部分:

仅能保证两个数之间没有括号的减法不出现负数,除法不出现余数

软件工程课程作业(二)--四则运算2改进版(c++)的更多相关文章

  1. 软件工程课程作业(三)--四则运算3(C++)

    伙伴链接:http://www.cnblogs.com/haoying1994/ 一.设计思路 在此前程序拥有的功能:加减有无负数,除法有无余数以及算式可定制的功能的基础上,此次程序又添加了算式结果的 ...

  2. 软件工程课程作业(一)—20道随机四则运算题(C++)

    一.编程思想: 1.定义所需要变量2.设置数组,存储运算符,3.通过随机函数random(0,100)找出运算数,random(0,4)找出运算符4.通过输出显示运算式. 二.源代码: //2016 ...

  3. 【软件工程Ⅱ】作业二 |分布式版本控制系统Git的安装与使用

    本次作业的要去来自于:https://edu.cnblogs.com/campus/gzcc/GZCC-16SE2/homework/2097 远程库地址:https://github.com/Mol ...

  4. 软件工程大作业(学生会管理系统)Web端个人总结报告

    软件工程大作业(学生会管理系统)Web端个人总结报告 一.小组信息 1.所在小组:第二组 2.小组选题:学生会管理系统 3.项目源代码链接: Web端源代码:code 小程序端源代码:code APP ...

  5. BUAA 2020 软件工程 热身作业

    BUAA 2020 软件工程 热身作业 Author: 17373051 郭骏 项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 第一次作业-热身! ...

  6. coursea机器学习课程作业

    coursea机器学习课程作业 一 关于此课程 课程地址 图片来自网络 1.官网课程地址传送 2.如果访问官网速度较慢可以上 B站课程地址 机器学习是一门研究在非特定编程条件下让计算机采取行动的学科. ...

  7. [2019BUAA软件工程]结对作业

    Tips Link 作业链接 [2019BUAA软件工程]结对作业 GitHub地址 WordChain PSP表格 psp2.1   预估耗时(分钟) 实际耗时(分钟) Planning 计划 60 ...

  8. THE LAST ONE!! 2017《面向对象程序设计》课程作业八

    THE LAST ONE!! 2017<面向对象程序设计>课程作业八 031602230 卢恺翔 GitHub传送门 题目描述 1.时间匆匆,本学期的博客作业就要结束了,是否有点不舍,是否 ...

  9. 自我介绍for软件工程课程

    石家庄铁道大学学生,正在学习软件工程课程. 对于软件工程课程,没什么太大的希望.度了一下,发现软件工程课程近年来比较脱节,这次用新课本不知道效果怎么样.嗯,等课本到手看看再说吧. 自己的目标:我希望能 ...

随机推荐

  1. visual studio 2013连接Oracle 11g并获取数据:(一:环境搭建)

    C# WinForm案例: 目标: visual studio 中点击按钮,就可获取到Oracle中数据表的内容 1.安装Visual Studio 2013 ,推荐如下网址,下载ISO镜像,一路ne ...

  2. bzoj 3687 bitset的运用

    题目大意: 小呆开始研究集合论了,他提出了关于一个数集四个问题:1. 子集的异或和的算术和.2. 子集的异或和的异或和.3. 子集的算术和的算术和.4. 子集的算术和的异或和.目前为止,小呆已经解决了 ...

  3. Terminating app due to uncaught

    1>Images.xcassets: A 60x60@2x app icon is required for iPhone apps targeting iOS 7.0 and later 图片 ...

  4. Hibernate对象映射类型

    Hibernate understands both the Java and JDBC representations of application data. The ability to rea ...

  5. SharePoint 2013 Nintex Workflow 工作流帮助(六)

    博客地址 http://blog.csdn.net/foxdave 工作流动作 7. Call web service(Integration分组) 一个调用WebService的操作. 自然,配置项 ...

  6. IOS 实现自定义的导航栏背景以及自定义颜色的状态栏(支持7.0以及低版本)

    为尊重文章原作者,转载务必注明原文地址:http://www.cnblogs.com/wt616/p/3784717.html 先看效果图: 在自定义导航栏背景时,可能会遇到以下一些问题: 1.当设置 ...

  7. ArrayList的使用方法【转载】

    *** Source URL: http://i.yesky.com/bbs/jsp/view.jsp?articleID=889992&forumID=150 *** 1.什么是ArrayL ...

  8. mycat启动后,用Navicat Premium 连接报 "2013"

    最近在学习mycat,启动后,用Navicat Premium 连接报 "2013"  Lost Connection During Query ,经过一顿百度也没发现是怎么回事, ...

  9. 2016- 1- 16 NSThread 的学习

    一:NSThread的概念: 二:NSThread的使用: 1.创建一个Thread 1.1第一种方法: - (void)test1{ NSString *str = @"zhengli&q ...

  10. 迪士尼黑科技:爬墙机器人 VertiGo

    12 月 30 日,迪士尼研发出的一款爬墙机器人曝光了一段有趣的视频.从视频里可看出这个机器人碰到墙壁时迅速地作出反应爬了上去. 据了解,这个爬墙机器人名叫 VertiGo,由迪士尼研究中心和苏黎世联 ...