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()')