源代码已上传至码云,https://gitee.com/liudanxi/codes/njpay3luk8g1iv6bfs9t536
题目:
(1)能自动生成小学四则运算题目,并且不能出现负数;
(2)能支持真分数的四则运算;
思路:
(1)四则运算加减乘除,采用两个随机数,由于不能出现负数,则对两个随机数进行比较大小再进行减法运算,除法一向特殊,所以在随机数的取值范围中设置不包括0。
(2)真分数运算在pycharm中导入fractions库,其余类似。
实现过程:
设计三个函数:
def newint() 生成整数四则运算
def newfra() 生成真分数四则运算
def newtest() 生成制定指定数量的四则运算题目
函数关系:
newint()与newfra()为独立的函数,负责生成随机四则运算,newtest()则随机调用上述两个函数生成题目。详细描述请看下方代码说明
代码说明:
首先说明整数的四则运算,生成两个随机数并随机运算,在减法中比较大小防止出现负数,在除法中比较大小并循环取整除的随机数组合。最后输出算式并返回正确答案。
1 def newint(): 2 opr = ['+', '-', '×', '÷'] 3 fh = random.randint(0, 3) 4 n1 = random.randint(1, 20) 5 n2 = random.randint(1, 20) 6 rjg = 0 7 if fh == 0: 8 rjg = n1 + n2 9 elif fh == 1: 10 n1, n2 = max(n1, n2), min(n1, n2) 11 rjg = n1 - n2 12 elif fh == 2: 13 rjg = n1 * n2 14 elif fh == 3: 15 n1, n2 = max(n1, n2), min(n1, n2) 16 while n1 % n2 != 0: 17 n1 = random.randint(1, 10) 18 n2 = random.randint(1, 10) 19 n1, n2 = max(n1, n2), min(n1, n2) 20 rjg = int(n1 / n2) 21 print(n1, opr[fh], n2, '= ', end='') 22 return rjg
真分数四则运算类似。
1 def newfra(): 2 opr = ['+', '-', '×', '÷'] 3 fh = random.randint(0, 3) 4 t1 = random.randint(1, 10) 5 t2 = random.randint(t1, 10) 6 n1 = Fraction(t1, t2) 7 t1 = random.randint(1, 10) 8 t2 = random.randint(t1, 10) 9 n2 = Fraction(t1, t2) 10 rjg = 0 11 if fh == 0: 12 rjg = n1 + n2 13 elif fh == 1: 14 n1, n2 = max(n1, n2), min(n1, n2) 15 rjg = n1 - n2 16 elif fh == 2: 17 rjg = n1 * n2 18 elif fh == 3: 19 n1, n2 = max(n1, n2), min(n1, n2) 20 rjg = n1 / n2 21 print(n1, opr[fh], n2, '= ', end='') 22 return rjg
newtest()函数是要求用户输入一个整数来输出算式的数量,采用while循环随机生成整数或者真分数运算,将答案保存在rjg列表的同时输出算式直到算式数量达到要求。最后输出rjg列表即输出答案。
def newtest(): opr = ['+', '-', '×', '÷'] print('输入题库所需要的题目数量') n=int(input()) rjg=[] m=0 while m<=(n-1): fh = random.randint(0, 4) if fh==0: print(m+1,end='、') rjg.append(newfra()) print(' ') else: print(m+1,end='、') rjg.append(newint()) print(' ') m=m+1 m=0 print('答案:') while m<=(n-1): print(m+1,'、',rjg[m]) m=m+1
下列为主函数,第一个模式负责调用上述newint()、new函数,并获得函数返回值即算式答案,与用户输入值进行比较。第二个模式则是生成算式题目。
1 print('1、四则运算') 2 print('2、制作题库') 3 n=int(input()) 4 if n==1: 5 print('input "0000" to Quit') 6 while True: 7 fh = random.randint(0, 4) 8 if fh == 0: 9 rjg = newfra() 10 jg = input() 11 if jg == '0000': 12 break; 13 sr = Fraction(jg) 14 if sr == rjg: 15 print('right') 16 else: 17 print('error. the Tight answer is', rjg) 18 else: 19 rjg = newint() 20 jg = input() 21 if jg == '0000': 22 break; 23 sr = int(jg) 24 if sr == rjg: 25 print('right') 26 else: 27 print('error. the Tight answer is', rjg) 28 if n==2: 29 newtest()
测试运行:
先测试运行第一个模式,如下图:
第二个模式,先输出30个算式数量:
输出1000个算式数量,运行完成且无报错,部分截图如下:
PSP表格:
预计耗时(分钟) | 是实际耗时(分钟) | ||
Planning | 计划 | 10 | 10 |
Estimate | 估计这个任务需要多少时间 | / | / |
Development | 开发 | 120 | 240 |
Analysis | 需求分析 | 5 | 10 |
Design Spec | 生成设计文档 | / | / |
Design Review | 设计复审(和同事审核设计文档) | / | / |
Coding Standerd | 代码规范(为目前的开发制定合适的规范) | / | / |
Design | 具体设计 | 5 | 10 |
Coding | 具体编码 | 30 | 60 |
Code Review | 代码复审 | 5 | 10 |
Text | 测试(自测,修改代码,提交修改) | 10 | 30 |
Reporting | 报告 | 10 | 20 |
Text Report | 测试报告 | 10 | 20 |
Size Measurement | 计算工作量 | / | / |
Postmortem & Process Improvement Plan | 事后总结,并提出过程改进计划 | / | / |
Sum | 合计 | 205 | 410 |
来源:https://www.cnblogs.com/liudanxi/p/10563737.html