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