python中加减乘除_python的四则运算练习(更新)

题目要求:

(1)更新已有程序

解题思路描述:

(1)更新主界面的说明

设计实现过程:

追加说明

代码说明:

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

1 defnewint():

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 returnrjg

23 '''jg = input()

24 sr = int(jg)

25 if int(sr) == rjg:

26 print('right')

27 else:

28 print('error. the Tight answer is', 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 =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 returnrjg

23 '''jg = input()

24 sr = Fraction(jg)

25 if sr == rjg:

26 print('right')

27 else:

28 print('error. the Tight answer is', rjg)'''

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

1 defnewtest():

2 opr = ['+', '-', '×', '÷']

3 print('输入题库所需要的题目数量')

4 n=int(input())

5 rjg=[]

6 m=0

7 while m<=(n-1):

8 fh = random.randint(0, 4)

9 if fh==0:

10 print(m+1,end='、')

11 rjg.append(newfra())

12 print(' ')

13 else:

14 print(m+1,end='、')

15 rjg.append(newint())

16 print(' ')

17 m=m+1

18 m=0

19 print('答案:')

20 while m<=(n-1):

21 print(m+1,'、',rjg[m])

22 m=m+1

下列为主函数,第一个模式负责调用上述newint()、new函数,并获得函数返回值即算式答案,与用户输入值进行比较。第二个模式则是生成算式题目

print('欢迎使用四则运算生成器')print('1、四则运算')print('2、制作题库')

n=int(input())if n==1:print('input "0000" to Quit')whileTrue:

fh= random.randint(0, 4)if fh ==0:

rjg=newfra()

jg=input()if jg == '0000':break;

sr=Fraction(jg)if sr ==rjg:print('right')else:print('error. the Tight answer is', rjg)else:

rjg=newint()

jg=input()if jg == '0000':break;

sr=int(jg)if sr ==rjg:print('right')else:print('error. the Tight answer is', rjg)if n==2:

newtest()

测试运行:

查看主界面的变化,如下图:

1623676-20190408151921210-373942754.png

改进程序性能过程:

(1)追加标题

PSP表格:

预计耗时(分钟)

是实际耗时(分钟)

Planning

计划

5

15

Estimate

估计这个任务需要多少时间

5

10

Development

开发

100

150

Analysis

需求分析

2

15

Design Spec

生成设计文档

20

30

Design Review

设计复审(和同事审核设计文档)

10

20

Coding Standerd

代码规范(为目前的开发制定合适的规范)

30

50

Design

具体设计

10

30

Coding

具体编码

40

100

Code Review

代码复审

3

15

Text

测试(自测,修改代码,提交修改)

15

40

Reporting

报告

20

40

Text Report

测试报告

5

15

Size Measurement

计算工作量

10

15

Postmortem & Process Improvement Plan

事后总结,并提出过程改进计划

10

20

Sum

合计

280

565

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值