大家手机里都有一个出厂自带的计算器,需要用的时候直接掏出手机就能计算,特别的方便。
还记得我上小学and中学的时候,都会花10几块钱,买一个计算器、方便数学题目计算。
那时候好像进考场也可以带着计算器??
应该也许有可能是叭!!
还有小时候很多大妈大爷的菜市场见到的计算器是很常见的,所以可见计算器的应用之广泛。
该计算器思路:
ps:思路不一样哈 仅供参考
1、递归寻找表达式中只含有 数字和运算符的表达式,并计算结果
2、由于整数计算会忽略小数,所有的数字都认为是浮点型操作,以此来保留小数
使用技术:
1、正则表达式
2、递归
二、流程图:
效果图如下😍😍😍😍😍😍:
附代码:
import re,os,sysdef compute_exponent(arg):""" 操作指数:param expression:表达式:return:计算结果"""val = arg[0]pattern = repile(r'd+.?d*[*]{2}[+-]?d+.?d*')mch = pattern.search(val)if not mch:returncontent = pattern.search(val).group()if len(content.split('**'))>1:n1, n2 = content.split('**')value = float(n1) ** float(n2)else:passbefore, after = pattern.split(val, 1)new_str = "%s%s%s" % (before,value,after)arg[0] = new_strcompute_exponent(arg)def compute_mul_div(arg):""" 操作乘除:param expression:表达式:return:计算结果"""val = arg[0]pattern = repile(r'd+.?d*[*/%//]+[+-]?d+.*d*')mch = pattern.search(val)if not mch:returncontent = pattern.search(val).group()if len(content.split('*'))>1:n1, n2 = content.split('*')value = float(n1) * float(n2)elif len(content.split('//'))>1:n1, n2 = content.split('//')value = float(n1) // float(n2)elif len(content.split('%'))>1:n1, n2 = content.split('%')value = float(n1) % float(n2)elif len(content.split('/'))>1:n1, n2 = content.split('/')value = float(n1) / float(n2)else:passbefore, after = pattern.split(val, 1)new_str = "%s%s%s" % (before,value,after)arg[0] = new_strcompute_mul_div(arg)def compute_add_sub(arg):""" 操作加减:param expression:表达式:return:计算结果"""while True:if arg[0].__contains__('+-') or arg[0].__contains__("++") or arg[0].__contains__('-+') or arg[0].__contains__("--"):arg[0] = arg[0].replace('+-','-')arg[0] = arg[0].replace('++','+')arg[0] = arg[0].replace('-+','-')arg[0] = arg[0].replace('--','+')else:breakif arg[0].startswith('-'):arg[1] += 1arg[0] = arg[0].replace('-','&')arg[0] = arg[0].replace('+','-')arg[0] = arg[0].replace('&','+')arg[0] = arg[0][1:]val = arg[0]pattern = repile(r'd+.?d*[+-]{1}d+.?d*')mch = pattern.search(val)if not mch:returncontent = pattern.search(val).group()if len(content.split('+'))>1:n1, n2 = content.split('+')value = float(n1) + float(n2)else:n1, n2 = content.split('-')value = float(n1) - float(n2)before, after = pattern.split(val, 1)new_str = "%s%s%s" % (before,value,after)arg[0] = new_strcompute_add_sub(arg)def compute(expression):""" 操作加减乘除:param expression:表达式:return:计算结果"""inp = [expression,0]# 处理表达式中的指数compute_exponent(inp)# 处理表达式中的乘除求余等compute_mul_div(inp)# 处理表达式的加减compute_add_sub(inp)if divmod(inp[1],2)[1] == 1:result = float(inp[0])result = result * -1else:result = float(inp[0])return resultdef exec_bracket(expression):""" 递归处理括号,并计算:param expression: 表达式:return:最终计算结果"""pattern = repile(r'(([+-*/%//**]*d+.*d*){2,})')# 如果表达式中已经没有括号,则直接调用负责计算的函数,将表达式结果返回,如:2*1-82+444#if not re.search('(([+-*/]*d+.*d*){2,})', expression):if not pattern.search(expression):final = compute(expression)return final# 获取 第一个 只含有 数字/小数 和 操作符 的括号# 如:# ['1-2*((60-30+(-40.0/5)*(9-2*5/3+7/3*99/4*2998+10*568/14))-(-4*3)/(16-3*2))']# 找出:(-40.0/5)content = pattern.search(expression).group()# 分割表达式,即:# 将['1-2*((60-30+(-40.0/5)*(9-2*5/3+7/3*99/4*2998+10*568/14))-(-4*3)/(16-3*2))']# 分割更三部分:['1-2*((60-30+( (-40.0/5) *(9-2*5/3+7/3*99/4*2998+10*568/14))-(-4*3)/(16-3*2))']before, nothing, after = pattern.split(expression, 1)print('before:',expression)content = content[1:len(content)-1]# 计算,提取的表示 (-40.0/5),并活的结果,即:-40.0/5=-8.0ret = compute(content)print('%s=%s' %( content, ret))# 将执行结果拼接,['1-2*((60-30+( -8.0 *(9-2*5/3+7/3*99/4*2998+10*568/14))-(-4*3)/(16-3*2))']expression = "%s%s%s" %(before, ret, after)print('after:',expression)print("="*10,'previous result is',"="*10)# 循环继续下次括号处理操作,本次携带者的是已被处理后的表达式,即:# ['1-2*((60-30+ -8.0 *(9-2*5/3+7/3*99/4*2998+10*568/14))-(-4*3)/(16-3*2))']# 如此周而复始的操作,直到表达式中不再含有括号return exec_bracket(expression)# 使用 __name__ 的目的:
# 只有执行 python index.py 时,以下代码才执行
# 如果其他人导入该模块,以下代码不执行
if __name__ == "__main__":flag = Trueos.system('clear') ###清屏###print('n================================================================')print('