python的四则运算练习(更新)

源代码已上传至Github,https://github.com/akino-liuxing/sizeyusuan-data-up-,中的sizeyunsuan.py文件

题目要求:

  (1)更新已有程序

解题思路描述:

  (1)更新主界面的说明

设计实现过程:

  追加说明

代码说明:

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

 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 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 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 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 def newtest():
 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')
    while True:
        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()

测试运行:

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

 

改进程序性能过程:


  (1)追加标题

PSP表格:

  预计耗时(分钟)是实际耗时(分钟)
Planning计划515
Estimate估计这个任务需要多少时间510
Development开发100150
Analysis需求分析215
Design Spec生成设计文档2030
Design Review设计复审(和同事审核设计文档)1020
Coding Standerd代码规范(为目前的开发制定合适的规范)3050
Design具体设计1030
Coding具体编码40100
Code Review代码复审315
Text测试(自测,修改代码,提交修改)1540
Reporting报告2040
Text Report测试报告515
Size Measurement计算工作量1015
Postmortem & Process Improvement Plan事后总结,并提出过程改进计划1020
Sum合计280565
 

转载于:https://www.cnblogs.com/lingxingyitiao/p/10670736.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值