PSP流程下四则运算升级

一、需求分析

1.输入参数n,随机产生n道加减乘除

2.数字在1-100,运算符3-5个

3.无负数和非整数

4.一个算式最少两种运算符

5.附带学号输出result.txt文件

 

二、功能设计

基本功能:四则运算,随机产生n道算式

扩展功能:能够计算括号

 

三、代码实现

import profile
import random
from fractions import Fraction

#四则运算

def szys():

    sym = ['+', '-', '×', '÷']

    f= random.randint(0, 3)

    z = random.randint(0, 1)#设置一个随机值,如果是1就进行整数运算,如果是0进行分数运算

    n1 = random.randint(1, 20)

    n2 = random.randint(1, 20)

    n3 = random.randint(1, 20)

    n4 = random.randint(1, 20)

    result = 0

    if z==0 :

        n1, n2 = max(n1, n2), min(n1, n2)

        if f == 0:#加法

            result  = n1 + n2

        elif f == 1:#减法,要先比较大小,防止输出负数

            n1, n2 = max(n1, n2), min(n1, n2)

            result  = n1 - n2

        elif f== 2:#乘法

            result  = n1 * n2

        elif f == 3:#除法,要比较大小,并循环取整除

            n1, n2 = max(n1, n2), min(n1, n2)

            while n1 % n2 != 0:

                n1 = random.randint(1, 10)

                n2 = random.randint(1, 10)

                n1, n2 = max(n1, n2), min(n1, n2)

            result  = int(n1 / n2)

        print(n1, sym[f], n2, '= ', end='')

        return result

    if z == 1:

        n1, n2 = min(n1, n2), max(n1, n2)#把n1,n2中小的放在前面,保证f1为真分数

        n3, n4 = min(n3, n4), max(n3, n4)#把n3,n4中小的放在前面,保证f2为真分数

        f1 = Fraction(n1, n2)#初始化f1为n1/n2

        f2 = Fraction(n3, n4)#初始化f2为n3/n4

        if f == 0:#加法

            result  = f1 + f2

        elif f == 1:#减法,要先比较大小,防止输出负数

            f1, f2 = max(f1, f2), min(f1, f2)

            result  = f1 - f2

        elif f== 2:#乘法

            result  = f1 * f2

        elif f == 3:#除法,要比较大小,并循环取整除
            if n1<n2:
                result=0
            
        else:
            result=int(n1/n2)
            
        print(f1, sym[f], f2, '= ', end='')
        return result
    
print('输入go进行四则运算')
print('输入test进行性能测试')

n=input()

#当输入go时,进行四则运算,调用函数syzs()

if n=="go":

    while True:

        result  = szys()

        j= input()

        try:
            if int(j)== result :
                print('right')
            else:
                print('error.,the answer is', result )
        except:
            print("出现异常,结束运算")
            break
if n=="test":
    profile.run('szys()')

运行结果如图:

PSP流程下四则运算升级

 

上一篇:阿里云轻量级服务器上JDK及tomcat部署配置


下一篇:利用Matlab求解线性方程组