软件工程课程作业(二)--四则运算2改进版(c++)
题目要求:
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++)的更多相关文章
- 软件工程课程作业(三)--四则运算3(C++)
		
伙伴链接:http://www.cnblogs.com/haoying1994/ 一.设计思路 在此前程序拥有的功能:加减有无负数,除法有无余数以及算式可定制的功能的基础上,此次程序又添加了算式结果的 ...
 - 软件工程课程作业(一)—20道随机四则运算题(C++)
		
一.编程思想: 1.定义所需要变量2.设置数组,存储运算符,3.通过随机函数random(0,100)找出运算数,random(0,4)找出运算符4.通过输出显示运算式. 二.源代码: //2016 ...
 - 【软件工程Ⅱ】作业二 |分布式版本控制系统Git的安装与使用
		
本次作业的要去来自于:https://edu.cnblogs.com/campus/gzcc/GZCC-16SE2/homework/2097 远程库地址:https://github.com/Mol ...
 - 软件工程大作业(学生会管理系统)Web端个人总结报告
		
软件工程大作业(学生会管理系统)Web端个人总结报告 一.小组信息 1.所在小组:第二组 2.小组选题:学生会管理系统 3.项目源代码链接: Web端源代码:code 小程序端源代码:code APP ...
 - BUAA 2020 软件工程 热身作业
		
BUAA 2020 软件工程 热身作业 Author: 17373051 郭骏 项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 第一次作业-热身! ...
 - coursea机器学习课程作业
		
coursea机器学习课程作业 一 关于此课程 课程地址 图片来自网络 1.官网课程地址传送 2.如果访问官网速度较慢可以上 B站课程地址 机器学习是一门研究在非特定编程条件下让计算机采取行动的学科. ...
 - [2019BUAA软件工程]结对作业
		
Tips Link 作业链接 [2019BUAA软件工程]结对作业 GitHub地址 WordChain PSP表格 psp2.1 预估耗时(分钟) 实际耗时(分钟) Planning 计划 60 ...
 - THE LAST ONE!!   2017《面向对象程序设计》课程作业八
		
THE LAST ONE!! 2017<面向对象程序设计>课程作业八 031602230 卢恺翔 GitHub传送门 题目描述 1.时间匆匆,本学期的博客作业就要结束了,是否有点不舍,是否 ...
 - 自我介绍for软件工程课程
		
石家庄铁道大学学生,正在学习软件工程课程. 对于软件工程课程,没什么太大的希望.度了一下,发现软件工程课程近年来比较脱节,这次用新课本不知道效果怎么样.嗯,等课本到手看看再说吧. 自己的目标:我希望能 ...
 
随机推荐
- POJ 1050 To the Max 暴力,基础知识 难度:0
			
http://poj.org/problem?id=1050 设sum[i][j]为从(1,1)到(i,j)的矩形中所有数字之和 首先处理出sum[i][j],此时左上角为(x1,y1),右下角为(x ...
 - 2.精通前端系列技术之seajs模块化使工作更简单(二)
			
drag.js // JavaScript Document //B开发 define(function(require,exports,module){ function drag(obj){ ; ...
 - jQuery get post  碎片(远程html)加载
			
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
 - 《同一个类中不同方法之间的调用相关问题(省略的类名或者this)》
			
//同一个类中不同方法之间的调用相关问题(省略的类名或者this) class A { public void B() { System.out.println("b方法运行"); ...
 - 理解smart pointer之三:unique_ptr
			
unique_ptr最先在boost中被定义,后来被C++标准委员会选中为C++11的feature之一. std::unique_ptr is a smart pointer that retain ...
 - iOS 三种录制视频方式
			
随着每一代 iPhone 处理能力和相机硬件配置的提高,使用它来捕获视频也变得更加有意思.它们小巧,轻便,低调,而且与专业摄像机之间的差距已经变得非常小,小到在某些情况下,iPhone 可以真正替代它 ...
 - vc设置窗口透明
			
::SetWindowLong(GetSafeHwnd(), GWL_EXSTYLE, ::GetWindowLongPtr(GetSafeHwnd(), GWL_EXSTYLE) | WS_EX_L ...
 - oracle的存储结构
			
表空间 当一个用户被创建以后,随之就要为用户分配数据存储的空间,这在oracle中成为“表空间”(Tablespace). 在数据库中创建用户时,基于应用性能和管理的考虑,最好为不同的用户创建独立的表 ...
 - BZOJ 2442 修剪草坪
			
NOIP的时候一定要看清楚数据范围. #include<iostream> #include<cstdio> #include<cstring> #include& ...
 - css 时钟
			
(转自:http://www.cnblogs.com/Wenwang/archive/2011/09/21/2184102.html) <!DOCTYPE html> <html l ...