源代码已上传至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 计划 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
 
posted on 2019-04-08 15:21  流星一条  阅读(728)  评论(0编辑  收藏  举报