python的加减乘除运算_python四则运算

题目:

(1)能自动生成小学四则运算题目,并且不能出现负数;

(2)能支持真分数的四则运算;

思路:

(1)四则运算加减乘除,采用两个随机数,由于不能出现负数,则对两个随机数进行比较大小再进行减法运算,除法一向特殊,所以在随机数的取值范围中设置不包括0。

(2)真分数运算在pycharm中导入fractions库,其余类似。

实现过程:

设计三个函数:

def newint() 生成整数四则运算

def newfra() 生成真分数四则运算

def newtest() 生成制定指定数量的四则运算题目

函数关系:

newint()与newfra()为独立的函数,负责生成随机四则运算,newtest()则随机调用上述两个函数生成题目。详细描述请看下方代码说明

代码说明:

首先说明整数的四则运算,生成两个随机数并随机运算,在减法中比较大小防止出现负数,在除法中比较大小并循环取整除的随机数组合。最后输出算式并返回正确答案。

1 defnewint():2 opr = ['+', '-', '×', '÷']3 fh = random.randint(0, 3)4 n1 = random.randint(1, 20)5 n2 = random.randint(1, 20)6 rjg =07 if fh ==0:8 rjg = n1 +n29 elif fh == 1:10 n1, n2 =max(n1, n2), min(n1, n2)11 rjg = n1 -n212 elif fh == 2:13 rjg = n1 *n214 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 defnewfra():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 =011 if fh ==0:12 rjg = n1 +n213 elif fh == 1:14 n1, n2 =max(n1, n2), min(n1, n2)15 rjg = n1 -n216 elif fh == 2:17 rjg = n1 *n218 elif fh == 3:19 n1, n2 =max(n1, n2), min(n1, n2)20 rjg = n1 /n221 print(n1, opr[fh], n2, '=', end='')22 return rjg

newtest()函数是要求用户输入一个整数来输出算式的数量,采用while循环随机生成整数或者真分数运算,将答案保存在rjg列表的同时输出算式直到算式数量达到要求。最后输出rjg列表即输出答案。

defnewtest():

opr= ['+', '-', '×', '÷']print('输入题库所需要的题目数量')

n=int(input())

rjg=[]

m=0while 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+1m=0print('答案:')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 whileTrue: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()

测试运行:

先测试运行第一个模式,如下图:

10563737.html

1623702-20190320134306808-1272341325.png

第二个模式,先输出30个算式数量:

1623702-20190320133054366-720304006.png

1623702-20190320133116342-2096197279.png

输出1000个算式数量,运行完成且无报错,部分截图如下:

1623702-20190320133413354-1240250831.png

1623702-20190320133435077-300060742.png

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

10563737.html

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值