作业 2, 模拟计算器开发:
实现加减乘除及拓号优先级解析
用户输入 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )等类似公式后,必须自己解析里面的(),+,-,*,/符号和公式(不能调用eval等类似功能偷懒实现),运算后得出结果,结果必须与真实的计算器所得出的结果一致  2776672.6952380957

流程图:

详细代码:

 #!usr/bin/env python
#-*-coding:utf-8-*-
# Author calmyan
import re
#b='1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )'
#b='1 - 2 * ( (60-30 +(-40/5) * (9-2**5//3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)// (16-3*2) )'
#print(b) def list_format(b):#格式化字符串函数
b=re.sub(' ','',b)
b=[i for i in re.split('(\-?\d+\.*\d*)',b) if i]#循环判断,i 不为空,添加到列表 去空字符 -开头加后面的数字
#print(b)
tmp_list=[]#定义一个临时列表
while True:
if len(b)==0:break#如果列表为空就退出
emp=b.pop(0)#取出第一个元素
if (len(tmp_list)==0 and re.search('^\-\d*$',emp)) or (len(tmp_list)>0 and re.search('[\+\-\*\/\(\)]$',tmp_list[-1]) ):#判断开头与中间的负数
tmp_list.append(emp)
continue
sny_nl=[i for i in re.split('([\+\-\*\/\(\)])',emp) if i]#对运算符进行分割 for index, i in enumerate(sny_nl):
if i==' ':#去空格判断
sny_nl.pop(index)#删除空格项
tmp_list+=sny_nl return tmp_list#返回列表 def Prioty(str_n,i):#比较优先级函数
lev1=['+','-']
lev2=['*','/']
lev3=['(']
lev4=[')']
if str_n in lev1:
if i in lev2 or i in lev3:#如果str_n 为+ - i 在2,3级时返回小于
return 1
else:
return 3
elif str_n in lev2:#如果str_n 为*/ i 在3级时返回小于
if i in lev3:
return 1
else:
return 3
elif str_n in lev3:#如果str_n 为(i 在4级时返回等于
if i in lev4:
return 2
else:
return 1 def sny(str):#判断是否为运算符
sny_l=['+','-','*','/','**','//','(',')']
tag=False
if str in sny_l:
return True#是运算符返回真
else:
return tag def opera(num1,operation,num2):#运算函数
res=0
if operation=='+':
res=num1+num2
if operation=='-':
res=num1-num2
if operation=='*':
res=num1*num2
if operation=='/':
res=num1/num2
return res def main(c):#主函数
numbe_list=[]#定义数字堆栈
sny_list=[]#定义运算符堆栈
for i in c:
if sny(i):#不是运算运
while True:
#print(numbe_list)
#print(sny_list)
if len(sny_list)==0:#如果列表为空,即第一个就无条件加入
sny_list.append(i)
break
prty=Prioty(sny_list[-1],i)#
if prty==1:#如果为一级
sny_list.append(i)#运算符继续添加
break
elif prty==2:#如果为二级
sny_list.pop()#运算符要取出最后一个
break
elif prty==3:#如果为三级
operation=sny_list.pop()#运算符==取出最后一个
num2=numbe_list.pop()#取出数字二
num1=numbe_list.pop()#取出数字一
numbe_list.append(opera(num1,operation,num2))#数字列表添加运算的结果
#print(numbe_list,sny_list)
continue
else:
i = float(i)#转为浮点数
numbe_list.append(i)#添加到数字列表
else:
operation=sny_list.pop()#运算符==取出最后一个
num2=numbe_list.pop()#取出数字二
num1=numbe_list.pop()#取出数字一
numbe_list.append(opera(num1,operation,num2))#数字列表添加运算的结果
#print(numbe_list,sny_list)
if len(sny_list):#如果运算符列表不为空再做一个运算
operation=sny_list.pop()#运算符==取出最后一个
num2=numbe_list.pop()#取出数字二
num1=numbe_list.pop()#取出数字一
numbe_list.append(opera(num1,operation,num2))#数字列表添加运算的结果
return numbe_list[0] #程序开始
print("\033[35;1m欢迎使用python简易计算器\033[0m".center(60,'='))
if __name__ =='__main__':
while True:
b=input('请输入你要计算的内容,按\033[31;1mQ/q\033[0m退出:')
if b=='q' or b=='Q':
exit()
#print(c)
try:
c=list_format(b)#运行输入函数格式化字符串,存入列表
number=main(c)
print(number)
except Exception as e:#出错可返回操作
print('输入有误,请重新输入')

python第二十一天---昨天没写完作业的更多相关文章

  1. Word 双栏排版最后多一页空白页删不掉、左栏文字没写完就到右栏了

    1. 问题 问题:Word双栏排版,最后多一页空白页,删不掉.如图: 原因分析:删不掉是因为末尾文字处其实有个下一页分节符,只不过可能看不到. 如何清晰的看到? 视图 > 大纲,就可以看到了.如 ...

  2. XObject.java 对象还没写完,希望电脑不会丢失。坏笑,早点见。

    /*面向对象强调的是对象, 面向过程强调的是功能行为,打开行为,关闭行为,执行行为,把多个行为封装成对象执行更强大的功能就是面向对象,是把多个函数, 多 个行为封装在一起,单一的函数执行对象的功能太困 ...

  3. 【Luogu】【关卡2-7】深度优先搜索(2017年10月)【AK】【题解没写完】

    任务说明:搜索可以穷举各种情况.很多题目都可以用搜索完成.就算不能,搜索也是骗分神器. P1219 八皇后 直接dfs.对角线怎么判断:同一条对角线的横纵坐标的和或者差相同. #include < ...

  4. python Web抓取(一)[没写完]

    需要的模块: python web抓取通过: webbrowser:是python自带的,打开浏览器获取指定页面 requests:从因特网上下载文件和网页 Beautiful Soup:解析HTML ...

  5. QBXT Day2主要是数据结构(没写完先占坑)

    简单数据结构 本节课可能用到的一些复杂度: O(log n). 1/1+1/1/.....1/N+O(n log n) 在我们初学OI的时候,总会遇到这么一道题. 给出N次操作,每次加入一个数,或者询 ...

  6. D5(太长了md没写完)

    动态规划 三种常见实现方法 对于一个斐波那契数列,我们想要求第n项的值,就需要一项一项的递归来求 来看代码 f[o] = 0; f[1] = 1; for (int i = 2; i <= n; ...

  7. 前端性能测试工具 : dynaTrace Ajax (还没写完)

    今天开始写这个工具, #什么是dynaTrace Ajax? 随着 jQuery.Dojo.YUI 等框架的兴起让构建 Web2.0 应用更加容易,但随之带来的定位等应用问题也越来越难,尤其是与性能相 ...

  8. D3(没写完

    说在博客前 这篇博客有许多使用到 STL 的地方,由于本人实在是记不全,所以我也参考了北大的一些教材,就别说我黈力了 QwQ 数据结构 今天讲的是数据结构啦(也是我这个蒟蒻最喜欢的 一些天天见面的好盆 ...

  9. mock的使用及取消,node模仿本地请求:为了解决前后端分离,用户后台没写完接口的情况下

    借鉴:https://www.jianshu.com/p/dd23a6547114 1.说到这里还有一种是配置node模拟本地请求 (1)node模拟本地请求: 补充一下 [1]首先在根目录下建一个d ...

随机推荐

  1. python zip压缩文件 并移动到指定目录

    需要引入的3个包: import os import shutil import zipfile 1. # 创建zip文件对象your_zip_file_obj = zipfile.ZipFile(' ...

  2. keras中的mini-batch gradient descent (转)

    深度学习的优化算法,说白了就是梯度下降.每次的参数更新有两种方式. 一. 第一种,遍历全部数据集算一次损失函数,然后算函数对各个参数的梯度,更新梯度.这种方法每更新一次参数都要把数据集里的所有样本都看 ...

  3. 喜大普奔,SITE4J网站上线啦

    喜大普奔,SITE4J网站上线啦: 你懂的:https://peterchenhdu.club/

  4. PHP-CPP开发扩展(二)

    PHP-CPP是一个用于开发PHP扩展的C++库.本节讲解PHP输出和函数的实现. 输出和错误 上面的helloworld示例里,我们使用Php::out进行输出,并使用了std::endl换行刷新缓 ...

  5. leetcode — longest-common-prefix

    /** * Source : https://oj.leetcode.com/problems/longest-common-prefix/ * * Created by lverpeng on 20 ...

  6. Asp.net mvc 5 CRUD代码自动生成工具- vs.net 2013 Saffolding功能扩展

    Asp.net mvc 5 CRUD代码自动生成工具 -Visual Studio.net2013 Saffolding功能扩展 上次做过一个<Asp.net webform scaffoldi ...

  7. NABCD校园生活

    N(Need,需求) 在校师生得到的信息分散,极大的影响了师生的学习效率,所以就会有快速得到全面信息的需求,而我们的APP正是在解决这个问题. A(Approach,做法) 我们会在主页进行信息分类, ...

  8. SQL Server 2012使用Offset/Fetch Next实现分页

    在Sql Server 2012之前,实现分页主要是使用ROW_NUMBER(),在SQL Server2012,可以使用Offset ...Rows  Fetch Next ... Rows onl ...

  9. Modbus通信协议 【 初识 Modbus】

    Modbus协议     Modbus 协议是应用于电子控制器上的一种通用语言.通过此协议,控制器相互之间.控制器经由网络(例如以太网)和其它设备之间可以通信.它已经成为一通用工业标准.有了它,不同厂 ...

  10. .net MVC使用Session验证用户登录(转载)

    .net MVC使用Session验证用户登录   用最简单的Session方式记录用户登录状态 1.添加DefaultController控制器,重写OnActionExecuting方法,每次访问 ...