python四则运算

源代码已上传至码云,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

 

 

 

 

 

 

 

 

 

 

 

 

posted @ 2019-03-20 11:16  刘丹熙  阅读(774)  评论(0编辑  收藏  举报