码迷,mamicode.com
首页 > 其他好文 > 详细

团队-象棋游戏-模块开发过程

时间:2017-11-01 20:37:06      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:and   开发   app   dex   int   过程   sum   end   res   

# -*- encoding: utf-8 -*-


def md(l,x):
a = l.index(x)
if x == ‘*‘ and l[a + 1] != ‘-‘:
k = float(l[a - 1]) * float(l[a + 1])
elif x == ‘/‘ and l[a + 1] != ‘-‘:
k = float(l[a - 1]) / float(l[a + 1])
elif x == ‘*‘ and l[a + 1] == ‘-‘:
k = -(float(l[a - 1]) * float(l[a + 2]))
elif x == ‘/‘ and l[a + 1] == ‘-‘:
k = -(float(l[a - 1]) / float(l[a + 2]))
del l[a - 1], l[a - 1], l[a - 1]
l.insert(a - 1, str(k))
return l

def fun(s):
l = re.findall(‘([\d\.]+|/|-|\+|\*)‘,s)
sum=0
while 1:
if ‘*‘ in l and ‘/‘ not in l:
md(l, ‘*‘)
elif ‘*‘ not in l and ‘/‘ in l:
md(l, ‘/‘)
elif ‘*‘ in l and ‘/‘ in l:
a = l.index(‘*‘)
b = l.index(‘/‘)
if a < b:
md(l, ‘*‘)
else:
md(l, ‘/‘)
else:
if l[0]==‘-‘:
l[0]=l[0]+l[1]
del l[1]
sum += float(l[0])
for i in range(1, len(l), 2):
if l[i] == ‘+‘ and l[i + 1] != ‘-‘:
sum += float(l[i + 1])
elif l[i] == ‘+‘ and l[i + 1] == ‘-‘:
sum -= float(l[i + 2])
elif l[i] == ‘-‘ and l[i + 1] == ‘-‘:
sum += float(l[i + 2])
elif l[i] == ‘-‘ and l[i + 1] != ‘-‘:
sum -= float(l[i + 1])
break
return sum

 实现运算过程

def calculate(expression):
ex=[]
ans=0
if ‘(‘ not in expression:
ans=fun(expression)
return ans
for i in range(len(expression)):
if expression[i]==‘(‘:
ex.append(i) 
elif expression[i]==‘)‘: 
temp=0
sub=expression[ex[len(ex)-1]+1:i]
temp=fun(sub)
expression=expression[0:ex[len(ex)-1]]+str(temp)+expression[i+1:len(expression)+1]
ex.pop()
return calculate(expression)

s=‘1 - 2 * ( (60-30 +(-40/5+3) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )‘

print(1 - 2 * ( (60-30 +(-40/5+3) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) ))
s3=‘3*(4+50)-((100+40)*5/2-3*2*2/4+9)*(((3+4)-4)-4)‘                
print(3*(4+50)-((100+40)*5/2-3*2*2/4+9)*(((3+4)-4)-4))
print(calculate(s))                                                
print(calculate(s3))

团队-象棋游戏-模块开发过程

标签:and   开发   app   dex   int   过程   sum   end   res   

原文地址:http://www.cnblogs.com/Ggao/p/7768100.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!