实现自动生成30道四则运算题目(2)
2016-03-12 15:58
246 查看
这周老师在上周的程序基础上新加了一些要求:
1.题目避免重复
2.题目可以定制(数量/打印方式)
3.可以控制一下参数
(1)是否有乘除法
(2)是否有括号(最多可以支持十个数参与运算)
(3)数值范围
(4)加减有无负数
(5)除法有无余数
看到这些要求的时候我对比自己的程序发现需要对原来的程序做很大的改动也有了很多的想法:
1.括号不应该扩在*和/运算上
2.是否有乘除法可以把*/有+-来代替很容易解决
3.上次的算法我把取随机数包装成了一个没有形参的子函数这次有了取值范围我可以加两个形参:max,min用来保证取得的随机数在这个范围中
这次我的程序还是和上次一样用数组完成,每个参与运算的数我都会在数组上分配3个相邻的数,这3个数分别保证:1.运算符2.括号3.参与运算的数
由于时间关系,本次设计的程序要求1没有实现(思路是设计一个链用来保存已经符合要求的运算式子,把新生成的算数式子与以前的逐一验证),要求2的输出方式没有实现没有实现(思路是运用文件输入输出流)
实验结果
测试1.生成9道,不超过6个数,最大值为9,最小值为2的四则运算题:
测试2.生成6道加减无负数,乘除无余数,最大值为9,最小值为2的二则运算
1.题目避免重复
2.题目可以定制(数量/打印方式)
3.可以控制一下参数
(1)是否有乘除法
(2)是否有括号(最多可以支持十个数参与运算)
(3)数值范围
(4)加减有无负数
(5)除法有无余数
看到这些要求的时候我对比自己的程序发现需要对原来的程序做很大的改动也有了很多的想法:
1.括号不应该扩在*和/运算上
2.是否有乘除法可以把*/有+-来代替很容易解决
3.上次的算法我把取随机数包装成了一个没有形参的子函数这次有了取值范围我可以加两个形参:max,min用来保证取得的随机数在这个范围中
这次我的程序还是和上次一样用数组完成,每个参与运算的数我都会在数组上分配3个相邻的数,这3个数分别保证:1.运算符2.括号3.参与运算的数
由于时间关系,本次设计的程序要求1没有实现(思路是设计一个链用来保存已经符合要求的运算式子,把新生成的算数式子与以前的逐一验证),要求2的输出方式没有实现没有实现(思路是运用文件输入输出流)
#include<iostream> #include<string> #include<stdlib.h> #include<time.h> using namespace std; int suiji2(int min,int max) { int b=-1; b=rand(); if(b>max||b<min) { b%=max;//保证b<99 b+=max;//防止余数为负 b%=max; b+=1;//使得到的数在1~99之间 } return b; } void main() { int a[100],b=5,c=1; string str="+-/*"; while(1) //总循环可以无限生成题目 { c=1; //输入生成题目的条件 cout<<"一共出几道题:"; cin>>b; cout<<"是否有乘除法(1,0):"; cin>>a[98]; if(a[98]==0) { str="+-+-"; } cout<<"最多几个数(10个数之间):"; cin>>a[97]; cout<<"数值范围:\n最大值:"; cin>>a[96]; cout<<"最小值:"; cin>>a[95]; cout<<"加减有无负数(1或0)(如果输入1则默认俩则加减运算):"; cin>>a[94]; if(a[98]==1)//如果前面输入了不包括乘除法则此条件无意义 { cout<<"乘除有无余数(1或0)(如果输入1则默认俩则乘除运算):"; cin>>a[93]; } //结束输入生成题目的条件 while(b--) //循环一次生成一道题 { int num=suiji2(3,a[97]);cout<<endl; int i=0,j=0; while(i<=num*3) // 初始化数组 { a[i]=suiji2(a[95],a[96]); i++; } while(j<=num*3) { a[j]%=4;//运算符 a[j+1]%=2;//括号 if(a[j+1]==1) { a[j+4]=-1; } j+=3; } cout<<""; if(a[94]==1||a[93]==1) { num=2; } cout<<"No."<<c++<<":"; //题目计数器 if(num==2) //2则运算 { if(a[94]==1&&a[3]==1) { if(a[2]<a[5]) { cout<<a[5]<<str[a[3]]<<a[2]; } else cout<<a[2]<<str[a[3]]<<a[5]; } else if(a[3]==2&&a[93]==1) { if(a[2]%a[5]!=0) { cout<<a[2]-(a[2]%a[5])<<str[a[3]]<<a[5]; } else cout<<a[2]<<str[a[3]]<<a[5]; } else cout<<a[2]<<str[a[3]]<<a[5]; } else //多则运算 { j=1; while(j<=num*3) { if(a[j]==1&&j<num*3-3&&a[j+2]!=2&&a[j+2]!=3)cout<<"("; cout<<a[j+1]; if(a[j-3]==1&&j>3&&a[j-1]!=2&&a[j-1]!=3)cout<<")"; if(j<(num*3-3))cout<<str[a[j+2]]; j+=3; } } cout<<"="<<endl; } } }
实验结果
测试1.生成9道,不超过6个数,最大值为9,最小值为2的四则运算题:
测试2.生成6道加减无负数,乘除无余数,最大值为9,最小值为2的二则运算
相关文章推荐
- CodeForces 598A:Tricky Sum【数学】
- oracle 读取blob大文本字段
- strcpy函数的实现
- 【事务系列3】锁,你的兄弟姐妹还能再多点吗?
- 如何使用vi处理大文件(GB级别)?
- hdu4276树形dp
- css技巧篇
- Git与Svn
- 效果惊艳的代码编辑字体推荐
- php-7.0编译模块的出错
- Cocos2dx-- 3.0前后对比
- Java基础知识
- Inna and Choose Options
- 在嵌入式linux下搭建Boa Webserver
- 三. ServerSocket 用法详解(一)
- 改了信仰,”U秒英伟达,卡秒英特尔“
- 从统计看机器学习常见算法
- 【MySQL】MySQL无基础学习和入门之二:MySQL的安装
- react-js-04-组件
- 个人项目四则运算生成程序进展——第三周